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Synclavier 


Dans cette dernière partie de Le SAIS de New 

la série, nous examinons certains Énglahg go Itai eût. 
systèmes perfectionnés, qui ont MP Sn 
fait leur apparition depuis que perfectionnéésau monde. 
la musique électronique a A y EM 

que ele de se habituelles du 

commencé à intégrer la 

technologie numérique. 


synthétiseur, la machine 
SR S 


a la possibilité de stocker 
jusqu'à 10 mégaoctets 
de son sur disque dur. 


Le développement récent le plus significatif ayant 
marqué la musique électronique touche au 
domaine de l’enregistrement numérique. Non 
seulement la qualité d’enregistrement du son s’est 
améliorée de manière considérable, mais encore 
le terme « enregistrement » a changé de signifi- 
cation : il concerne maintenant de nombreuses 
et différentes techniques. Si nous comprenons 
que le terme enregistrement signifie aujourd’hui 
« codage numérique du son et son organisation 
en musique », nous commençons à saisir ce qui Fairlight CMI 


s’est produit en musique dans les années  L® Fairlight CMI fut l'un 
des premiers systèmes 


quatre-vingt. ’ . de musique utilisant un 
Depuis la Seconde Guerre mondiale, on a éta- ordinateur. Le système 


bli une norme pour l’enregistrement sur bande d'exploitation du Fairlight 
magnétique, et les formats vont de la toute petite St Sy RES 
microcassette aux grandes bobines de vingt- options aitant dé la 
quatre pistes utilisées dans les studios d’enre- ‘commande au clavier 
gistrement professionnels. jusqu'à la définition des 

Lors d’un enregistrement, les minuscules par- hs MP qu Cette 
ticules d’oxyde métallique sont redisposées dans pepe DA Droite 
des configurations complexes, qui sont analogues  -des copies imprimées. 
aux formes des ondes sonores qu’elles représen- 
tent. Lorsque la bande défile devant la tête de lec- 
ture d’une enregistreuse, ces configurations sont 
converties en une chaîne de tensions électriques. 
Ces tensions sont alors transmises aux haut- 
parleurs, qui reproduisent le son enregistré sur 
la bande. 


Roland MSQ:700 ge 
Le Roland MSQ:700 est ; 
considéré comme le 

meilleur Séquenceur 
compatible-avéc MIDI. Le 
Yamaha KX5 MSQ-700 offre la gamme 
L'interface MIDI du complète.des fonctions 


Puisque la disposition des particules peut être Yamaha KX5 permet MIDI et peut Stocker 
assez précisément appréciée par rapport à la tête d'établir un lien entre des jusqu'# 6 500:notes. 
de lecture, il est assez facile de savoir où se trouve me dm sb 
un son particulier sur une section de bande. Ce dispositif servira 
L’édition de la bande à l’aide de lames de rasoir aussi à établir l'interface 
démagnétisées est donc devenue une importante de l'ordinateur 
technique qui doit être maîtrisée par les ingénieurs Fe rennnié pied 
du son. 


En enregistrement numérique, le son est codé 
numériquement sur la bande, et la tête de lecture. 
devient un convertisseur numérique/analogique 
(N/A). Les haut-parleurs sont alimentés de la 
même manière qu'auparavant, mais ils utilisent 
les tensions générées par le convertisseur N/A. 
Pourvu que les données de conversion soient 
assez nombreuses, la bande numérique peut 
reproduire des sons d’une qualité bien supérieure 
à celle obtenue avec une bande magnétique. Et, 
aussi longtemps que les données demeurent intac- 
tes, la bande peut être copiée numériquement des 
centaines de fois, sans perte de qualité. 


Drumulator 

La batterie électronique 
Drumulator d'Emu 
Systems a une capacité 
mémoire de 10 088 notes 
à l'intérieur de 

64 chansons. Il est aussi 
possible d'insérer des 
ROM additionnelles pour 
produire des effets 
spéciaux, comme des 
percussions latines où 
africaines. 


lan McKinnell 


Échos du passé 

La description des sons 
faite par Francis Bacon 
(1561-1626) dans cet 
extrait semble prédire 
l'extraordinaire force 

et variété de la musique 
électronique d'aujourd'hui. 
(CI. Mary Evans.) 


De nombreux studios d'enregistrement se sont 
dotés d’enregistreuses numériques à vingt-quatre 
pistes. A l’aide de celles-là, la reproduction du 
son est si précise que même les ingénieurs du son 
ont du mal à déterminer si un son provenant des 
haut-parleurs du studio est produit par un 
instrument de musique, dans la zone d’enre- 
gistrement, ou par une bande numérique. Mais 
de nouveaux problèmes sont apparus : il n’est 
plus possible de « voir » où se trouvent les sons 
sur la bande numérique, ce qui rend l’édition 
beaucoup plus difficile. Le collage devient une 
technique dépassée. Le « bruit de studio » repré- 
sente une autre difficulté : il s’agit d’une carac- 
téristique indésirable, et généralement inaudible, 
de certains équipements de studio. La bande 
magnétique n’était pas assez sensible pour l’enre- 
gistrer, mais les enregistrements numériques ont 
tendance à la capter. 

Tandis que l’enregistrement sur vingt-quatre 
pistes est toujours imposé par les studios profes- 
sionnels, l’enregistrement numérique monopiste 
d’une qualité identique est offert à tout proprié- 
taire de magnétoscope domestique Betamax. La 
bande vidéo est un médium numérique, elle peut 
donc être utilisée pour coder tout type de don- 
nées. Le Sony PCM (Pulse Code Modulator) est 
une unité qui transforme un magnétoscope Beta- 
max en une enregistreuse de bande audio. Cette 


D'après “The New Atlantis" de Francis Bacon, 
publie en 1624. 
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Nous avons aussi Les maisons du bruit, où nous 
produisons, décrivons et expliquons tous Les sons. 
Nous avons des harmonies que vous n'avez pas, 
en quart de ton et en petits coulés musicaux. 
Divers instruments de musique également que 
vous ne connaissez pas, certains plus doux que 
n'importe lequel de ceux que vous possédez, qui 
associés aux cloches et sonneries donnent des 
sons d'une grande délicatesse. 

Nous transformons Les petits sons en grands 
bruits graves et profonds, et Les grands bruits en 
petits sons atténués et aigus. Nous produisons 
divers tremblements de sons qui, mêleés à des 
gazouillis, semblent tout à fait naturels. Nous 
imitons et répétons tous Les sons articulés, toutes 
Les voix et tous Les cris d'animaux et d'oiseaux, 
et nous utilisons des systèmes qui facilitent 


l'écoute. Nous avons aussi divers, étranges et 
artificiels echos qui réfléchissent La voix 


plusieurs fois, comme si elle était ballotée dans 
l'espace et d'autres, encore, dechirent La voix, 
restituant Les sons articules dans un ordre 
différent de celui reçu. Nous avons aussi Les 


unité peut rendre désuète les enregistrements ana- 
logiques de même taille. 

Le codage numérique du son, ou échantillon- 
nage, est le principe essentiel du Fairlight CMI 
(Computer Musical Instrument), l’un des sys- 
tèmes perfectionnés les plus connus. Le Fairlight 
peut échantillonner tout son pendant une période 
allant jusqu’à deux secondes, et il reproduit alors 
ce son sur une plage de six octaves. L’échantil- 
lonnage représente une véritable percée dans le 
domaine de la musique électronique. Pendant des 
années, les ingénieurs et les musiciens ont tenté 
de simuler les sons des instruments à cordes ou 
à vent à l’aide de synthétiseurs, et, dans certains 
cas, ils ont été très près d’atteindre leur but. Mais 
l’échantillonnage ne permet pas uniquement une 
remarquable reproduction d’un son d’instrument 
à cordes. Il peut produire le son d’un violon par- 
ticulier. Il peut même reproduire le son d’un 
joueur particulier dans une salle particulière. 
Dans un précédent article, nous avons vu com- 
ment les compositeurs de musique concrète des 
années cinquante passaient des semaines à assem- 
bler des fragments de bande magnétique pour 
produire des œuvres complètes. La manipulation 
des échantillons par ordinateur permet mainte- 
nant à un compositeur d’obtenir le même résul- 
tat en quelques minutes. 


Instruments d'échantillonnage 


Un instrument d’échantillonnage comme le Fair- 
light peut remédier aux limites naturelles des ins- 
truments musicaux. Par exemple, il est assez 
facile pour un flûtiste de produire, avec un souf- 
fle de qualité, un son chaud, dans le registre infé- 
rieur de la flûte. Il lui sera cependant impossible 
d’obtenir ce type de son deux octaves plus 
haut, au registre supérieur de l’instrument — la 
conception physique de la flûte l’interdisant. En 
revanche, un utilisateur de Fairlight peut échan- 
tillonner le son grave de qualité et le transposer 
deux octaves plus haut sur le clavier. Le résultat 
ressemblera toujours au son d’une flûte, mais 
dont l’équivalent réel ne peut exister. 

Le Fairlight peut produire un affichage sur 
écran de tous les sons échantillonnés, qui sont 
stockés sur une disquette de 8 pouces. Les 
différentes caractéristiques d’un son individuel 
peuvent être examinées successivement : il est 
souvent plus facile de déterminer ce qui est 
« mauvais » dans un son en l’examinant de cette 
façon, plutôt qu’en l’écoutant. De nombreux 
sons doivent être plus longs que la durée d’échan- 
tillon (de deux secondes). En constatant comment 
sont associées les différentes formes d’ondes du 
son, il est possible de sélectionner un point où 
le son pourrait être répété. Si on sélectionne le 
point approprié, une illusion de continuité peut 
être produite. Le son analogique ne se comporte 
évidemment pas comme cela. Aussi, la répétition 
du son choisi pourrait donner une dimension inu- 
sitée à la musique ainsi produite. 

L'utilisateur du Fairlight peut entrer la musi- 
que de deux manières, en plus du jeu « en temps 
réel » sur le clavier. La première méthode, dite 


« Page R », affiche une portée de cinq lignes, et 
l'utilisateur entre les notes sur la portée à partir 
du clavier musical. Toute erreur de synchronisa- 
tion peut être réparée automatiquement par 
l’ordinateur en se basant sur la mesure déjà défi- 
nie par l'utilisateur. 

La seconde méthode implique l’utilisation d’un 
langage de composition musical (MCL). Le MCL 
du Fairlight nécessite l’entrée de chaque note au 
clavier alphanumérique, mais il permet de modi- 
fier les différents paramètres au niveau de cha- 
que note. Le Fairlight a une capacité de huit voix, 
un utilisateur peut donc entrer huit séquences dif- 
férentes, jouées par huit « instruments » diffé- 
rents. Chacun de ceux-ci peut être très légèrement 
décalé par rapport aux autres, et l’exécution glo- 
bale est coordonnée par l’horloge interne du 
Fairlight. 

On peut se demander pourquoi une musique 
doit être exécutée de façon aussi « imprécise », 
surtout par un ordinateur. C’est que les musiciens 
ne jouent jamais en conservant exactement le 
même tempo. Le système Fairlight permet de 
simuler certains styles d'exécution. 

De nombreux musiciens s’inquiètent du fait 
que le Fairlight sera de plus en plus en mesure 
de les remplacer, la capacité de simulation de tels 
équipements continuant à évoluer. Des groupes 
comme Wang Chung, Duran Duran et Culture 
Club utilisent des Fairlight dans leur processus 
de réalisation, et il est souvent impossible de dis- 
tinguer ce qui est vraiment joué de ce qui est exé- 
cuté par le Fairlight. 

Bien qu’étant le plus connu, le Fairlight n’est 
pas le seul instrument de ce type offert sur le mar- 
ché. Le système Synclavier dispose de fonctions 
similaires, mais à une plus grande échelle. Les 
données sont stockées sur un disque dur d’une 
capacité de 40 méga-octets. Un disque complet 
peut être produit et enregistré à l’intérieur du 
système Synclavier, ce qui rend complètement 
inutile la présence d’une machine numérique à 
vingt-quatre pistes. 

Mais même le système Synclavier souffre de 
certaines restrictions. Actuellement, tous les ins- 
truments d’échantillonnage disponibles ont une 
chose en commun : ils reproduisent le son échan- 
tillonné de façon aussi précise que possible 
— sauf si l’utilisateur est intervenu pour faire une 
modification spécifique. Mais un trompettiste, en 
pleine représentation, peut apporter une modi- 
fication importante au son suivant en changeant 
simplement l’attaque du souffle ou la position des 
lèvres. Un bon musicien y parvient presque sans 
y penser. Les instruments d’échantillonnage doi- 
vent donc également produire un système qui 
obéit rapidement à la volonté du musicien. Le 
Kurzweil, qui n’est encore qu’un prototype, 
comporte un programme de reconnaissance de 

configuration. Cela signifie que, lorsqu’une note 
est jouée sur le clavier musical, de nombreux 
échantillons différents sont analysés et que les 
caractéristiques de chaque échantillon sont com- 
binées pour produire le son individuel. Un tel 
système permet de se rapprocher beaucoup plus 
du caractère et de la nature d’un véritable ins- 


trument de musique. La seule différence réside 
dans le fait que deux pianos n’offrent jamais 
deux sonorités exactement identiques alors que 
tous les « pianos » Kuzweïil CMI ont un carac- 
tère identique — sauf si les utilisateurs dévelop- 
pent leur propre logiciel de « caractère ». 

Une rumeur veut que Lucasfilm — la société 
responsable de la réalisation de Star Wars — 
mette actuellement au point un système encore 
plus évolué que le Fairlight, le Synclavier et le 
Kurzweil réunis. Nommé ASP (Audio Signal 
Processor), cet équipement est censé intégrer dans 
un seul système toutes les fonctions de gestion 
de son musical numérique actuellement offertes 
dans un grand studio musical complexe. Ainsi, 
à l'instar des ordinateurs et des synthétiseurs des 
années cinquante, qui occupaient plusieurs piè- 
ces et qui peuvent maintenant être posés sur un 
bureau, le studio d’enregistrement de l’avenir 
prendra probablement l’aspect d’un système 
portable. 

L'intégration de la technologie numérique n’a 
pas touché uniquement les systèmes et disposi- 
tifs de génération sonore. Les studios d’enre- 
gistrement modernes disposent en général de 
nombreuses unités de traitement du son 


dans leur équipement de base. L’unité de réver- 
bération est un bon exemple. Le son traverse 
une unité qui lui ajoute un écho ou une réverbé- 
ration, et les guitaristes de rock, ainsi que les pro- 
ducteurs de reggae ont utilisé ce type de traite- 
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MCL du Fairlight 

Le langage de 
composition musicale 
utilisé par le Fairlight est 
piloté par menus. Les 
choix sont ainsi effectués 
à partir de menus 
proposés à l'écran. 

Les signaux affichés à la 
page 1064 furent générés 
à l’aide d'une liste de 
paramètres sonores dans 
des instructions de 
données, similaires à un 
listage Basic, puis 
affichés et imprimés en 
utilisant des commandes 
du menu. 
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ment pour obtenir leur son musical particulier. 
Le quantec est une unité numérique qui, au lieu 
de produire uniquement une réverbération, 
réussit à simuler les types de réverbération qui 
se manifestent dans des pièces et dans des espa- 
ces de dimensions différentes. Son « espace 
acoustique » le plus petit est une boîte d’un 
volume de 1 m°, et les simulations prédéfinies 
offrent les dimensions d’un salon, d’une salle de 
concert, d’un hangar d’aviation ou bien d’une 
cathédrale. 

La fonction la plus intéressante du quantec est 
d’étendre la réverbération bien au-delà des limi- 
tes physiques et acoustiques naturelles. Dans le 
Midwest américain, au cours des années cin- 
quante, un petit studio de rockabilly avait été 
construit près d’un silo à céréales. C’est cet 
énorme espace qui permettait de créer le son par- 
ticulier du rockabilly dans ce studio. L’utilisation 
moderne d’unités numériques comme le quantec 
est plus banale, étant réservée principalement aux 
opérations de postproduction et au travail de 
cinéma. 

Les acteurs peuvent être filmés tout en parlant 
dans l’environnement acoustiquement neutre 
d’un studio, et la bande sonore sera traitée ulté- 
rieurement afin d’obtenir une résonance acous- 
tique qui corresponde à l’espace dans lequel 
l’action est censée se dérouler. 


Le défi 
de la musique électronique 


Nombreux sont ceux qui ont le sentiment que la 


Système Fairlight 
Ces affichages de 
signaux furent créés et 


imprimés sur un système des exemples de sons technologie numérique a une mauvaise influence 
uSIeeL FONTIONT CMI. PAIN ds sur la musique. Ils pensent que cette musique est 
Le premier est un signaux sont produits en sée d’ iè Il ificiell 1 
exemple d'ondes numérisant les sons réels illustrer les modifications Créée une MARICIE tellement art nçIe € que la 
sinusoïdales générées d’une voix humaine, pour apportées à la spontanéité et la créativité sont délaissées au pro- 
par le Fairlight à l’aide la deuxième illustration, composition de chaque fit d’un meilleur contrôle technique. C’est un 
de la synthèse FM. et d une trompette pour son à travers le temps. argument persuasif. Mais prenons la peine d’exa- 
Ce son fut fabriqué la troisième. Les : di ñ 1 I SE 

en combinant affichages sont en « trois miner un médium visuel — le cinéma — pour 


électroniquement des juger si cela est vraiment fondé. 

formes d'ondes. Les Depuis plusieurs décennies, la technologie ciné- 
autres impressions sont Prnu  #Et ; matographique a permis aux metteurs en scène 
RE de filmer des scènes sous différents angles, d’uti- 
liser des zooms puissants et d’effectuer de larges 
panoramiques. Il a été possible de répéter des 
séquences d’images, de les ralentir, de les accé- 
lérer, de les faire défiler en sens inverse, au cours 
du montage du film, pour créer des juxtaposi- 
tions d’images les plus diverses. Ce n’est que tout 
récemment, grâce à la technologie numérique, 
que les producteurs de musique ont commencé 
à vraiment contrôler le son. Le cinéma est géné- 
ralement reconnu comme un médium permettant 
une libre expression. Il est donc problable que 
la musique numérique sera considérée de la même 
manière. Actuellement, certains musiciens sont 
facilement un peu intimidés par tant de possibi- 
lités, et d’autres produisent une musique qui 
n'offre guère d’autre intérêt que technique. Pour 
les musiciens qui sont prêts à relever le défi de 
la musique électronique, les années quatre-vingt 
s’annoncent comme une décennie stimulante et 
créative. 


dimensions » pour 
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Commande d’un moteur 


Nous découvrons maintenant le logiciel requis pour mettre les 
moteurs sous tension, et nous développons un système simple de 


commande à rétroaction. 


La commande de dispositifs par micropro- 
cesseurs est de nos jours fort répandue dans 
l’industrie. Ses applications vont du comptage de 
bouteilles sur un tapis roulant à la soudure des 
châssis d’automobiles. Tous les systèmes de 
commande doivent d’abord assurer l’entrée de 
données provenant de l’extérieur sous une forme 
reconnue par un système à microprocesseur, 
ensuite analyser ces données et, enfin, provoquer 
les actions requises par cette analyse. Si ces trois 
interventions sont répétées de façon continue, le 
système assure une commande dite « à rétroac- 
tion ». 

Pour illustrer le principe de la commande à 
rétroaction, prenons l’exemple d’une casserole de 
soupe mijotant sur une cuisinière. Afin de cuire 
la soupe, la cuisinière doit fournir assez de cha- 
leur pour la faire légèrement bouillir, sans qu’elle 
déborde de la casserole. Pour ce faire, nous 
n’aurions qu’à appliquer une température maxi- 
male à la casserole jusqu’à ce que la soupe com- 
mence à bouillir; alors, il suffirait de baisser le 
feu de la plaque pour que la soupe mijote. Si elle 
recommençait à bouillir, nous devrions diminuer 
encore la chaleur de la plaque de la cuisinière. 
En effectuant ce type d’opérations, nous contrô- 
lons visuellement l’état de la soupe, nous analy- 
sons ce que nous voyons, et nous prenons les 
mesures appropriées. Nous devons répéter ces 
interventions jusqu’à ce que la soupe soit cuite. 
Un micro-ordinateur pourrait contrôler la cuis- 
son, mais d’une autre façon. La principale dif- 
férence résiderait dans le mode de contrôle de 
l’état de la soupe. Alors que nous pouvons regar- 
der la soupe et prendre une décision en nous 
basant sur notre expérience, un système informa- 
tique devrait utiliser une autre méthode, basée sur 
des données physiques facilement vérifiables, 
comme la température. Avant d’automatiser le 
contrôle de la soupe, il est nécessaire d’effectuer 
certaines expériences pour déterminer quelle tem- 
pérature correspond à un mijotement régulier, et 
à quelle température la soupe déborderait de la 
casserole. Cela étant fait, l’ordinateur pourrait 
se charger complètement de cette tâche, pourvu 
que l’on ait des dispositifs adéquats pour 
contrôler et pour régulariser la température. 

Des moteurs peuvent être commandés de 
diverses manières en utilisant le boîtier tampon 
et le boîtier de sortie à basse tension que nous 
avons construits. Un moteur de modèle réduit est 
idéal pour tester le logiciel que nous allons 
concevoir. Nous devons d’abord nous assurer que 


le moteur que nous connectons au boîtier de sor- 
tie a une valeur nominale de tension égale ou 
supérieure à celle de la tension d’entrée prove- 
nant du transformateur. En connectant les deux 
bornes du moteur à la ligne 0 du boîtier de sor- 
tie, nous pouvons mettre le moteur sous tension 
et hors tension en utilisant les touches Z et X du 
clavier. 


BBC MICRO 


10 REM SIMPLE MOTEUR BBC 

20 DDR = &FE62:DATREG = &FE60 

30 ?DDR=255:REM TOUTES LES LIGNES DE SORTIE 

40 ?DATREG=0:REM MOTEUR HORS TENSION 

50 REPEAT 

60 A$=INKEYSU):REM FRAPPE D'UNE TOUCHE? 

70 IF A$=4«Z» THEN ?DATREG=1:REM MISE SOUS TENSION 
80 UNTIL A$=4«X» 

00 ?DATREG=0:REM MISE HORS TENSION 


COMMODORE 64 

10 REM SIMPLE MOTEUR CBM 64 

20 DDR =56579:DATREG =56b77 

30 POKEDDR,265:REM TOUTES LIGNES DE SORTIE 


Mettre d’autres tampons 
Le boîtier tampon, notre 
première construction, 
sert à protéger les 
circuits de l'ordinateur 
contre des courants 
d'entrée ou de sortie trop 
élevés. Son alimentation 
indépendante alimente le 
boîtier de sortie — le 
projet plus récent — 

et autorise l'interruption 
commandée par logiciel 
de la sortie de 12 V. 

(CI. lan McKinnell.) 
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40 POKEDATREG,O:REM MOTEUR HORS TENSION 

50 GETAS:IFAS< >1Z» ANDAS< >4X» THEN 50 
:REM ATTENDRE LA FRAPPE D'UNE TOUCHE 

60 IF A$=4«Z»THEN POKEDATREG,1:GOTO 50 

70 IF A$=(«X»THEN POKEDATREG,0:END 


Nous pouvons commander la direction du 
moteur en connectant les bornes du moteur à des 
lignes adjacentes sur le boîtier de sortie. Le dia- 
gramme illustre ces connexions. Nous pouvons 
également utiliser un simple interrupteur à rup- 
ture, connecté à la ligne 7 du boîtier tampon pour 
commander la direction. 

Dans le programme suivant, une valeur de 1 
dans le registre de données entraîne dans le 
moteur une circulation de courant dans un sens. 
Placer une valeur de 2 dans le registre de don- 
nées fait circuler le courant dans la direction 
inverse. Le programme teste de façon répétitive 
la ligne 7 et ne place un 2 dans le registre de 
données que lorsque la ligne est au niveau bas 
(c’est-à-dire lorsque l’interrupteur est fermé). De 
cette façon, l’interrupteur commande la direction 
du moteur. Voici un exemple très simple de sys- 
tème de commande à rétroaction. 


BBC MICRO 


10 REM MOTEURS DIRIGÉS BBC 

20 DDR = &FE62:DATREG = &FE60 

30 ?DDR = 127:REM ENTRÉE LIGNE 7 

40 ?DATREG=0:REM MISE HORS TENSION 

50 A$=GETS:REM ATTENDRE LA FRAPPE D'UNE TOUCHE 
60 REPEAT 

70 IF A$=INKEYS(1) 

80 IF(2DATREG AND128)=0 THEN DIR =2 ELSE DIR=1 
80 ?DATREG = DIR 

100 UNTIL A$=«X»:REM PRESSER X POUR TERMINER 
110 ?DATREG=0:REM MISE HORS TENSION 


COMMODORE 64 


10 REM MOTEURS DIRIGÉS CBM 64 
20 DDR =565/9:DATREG =56677 


BOÎTIER TAMPON 
APE mer FRET 


VERS LE 
F= TRANSFORMATEUR 


INTERRUPTEUR 


BOÎTIER DE SORTIE 


30 POKEDDR,127:REM ENTRÉE LIGNE 7 

40 POKEDATREG,0:REM TOUS HORS TENSION 

50 GETAS:IFA$=4«» THEN 50:REM ATTENDRE LA FRAPPE D'UNE 
TOUCHE 

60 GETAS$ 

70 1F (PEEK(DATREG)AND128)=0 THEN POKEDATREG, 2:G0T090 

80 POKEDATREG, 1 

90 IFAS< >«X»THEN60 

100 POKEDATREG0:REM MISE HORS TENSION 


BBC MICRO 


10 REM COMMANDE DE MOTEUR VARIABLE BBC 
20 DDR = &FE62:DATREG = &FE60:SPEED = 30 

30 ?DDR=255:REM TOUTES LIGNES SORTIE 

40 ?DATREG=0:REM TOUTES HORS TENSION 

50 A$=GETS;REM ATTENDRE UNE TOUCHE 

60 REPEAT 

70 A$=INKEYS(1) 

80 ?DATREG=0:REM MISE HORS TENSION 

90 FORI=1T0(100- SPEED):NEXT:REM TEMPORISATION 1 
100 ?DATREG=1:REM MISE SOUS TENSION 

110 FORI=1TO SPEED:NEXT:REM TEMPORISATION 
120 IF A$=4«D»THEN SPEED = SPEED -5 

130 IF A$=«Z1 THEN SPEED = SPEED +5 

140 UNTIL A$=4X» 

150 ?DATREG=0:REM MISE HORS TENSION 


COMMODORE 64 


10 REM COMMANDE DE MOTEUR VARIABLE CBM 64 

20 DDR =565/9:DATREG = 56577: SPEED =30 

30 POKEDDR,265:REM TOUTES LIGNES SORTIE 

40 POKEDATREG,O:REM MOTEUR HORS TENSION 

50 GETAS:IFAS = «THEN 50:REM ATTENDRE UNE TOUCHE 
60 GETAS$ 

70 POKEDATREG=0:REM MISE HORS TENSION 

80 FOR 1=1 TO(100- SPEEDI:NEXT:REM TEMPORISATION 
90 POKEDATREG=1:REM MISE SOUS TENSION 

100 FOR 1=1 TO SPEED:NEXT:REM TEMPORISATION 2 
110 IF A$=4«D»THEN SPEED = SPEFD-5 

120 IF A$=«Z»THEN SPEED = SPEED +5 

130 IF A$< >4X»THEN 60 

140 POKEDATREG,0:REM MISE HORS TENSION 


Quatre roues motrices 
Les deux boîtiers 
séparent le bus des 
données de 
l'alimentation. Si chaque 
boîtier est conçu avec un 
raccord et une prise, ils 
peuvent être connectés 
entre eux, en chaîne. 

La voiture a un moteur 
de 12 V en continu, 
alimenté par le boîtier de 
sortie et arrêté par le 

bit 7 du boîtier tampon. 
La polarité des sorties 
peut être inversée, à 
partir du logiciel, de 
façon à permettre 
d'avancer ou de reculer. 


Kevin Jones 


Dans ce programme, la variable SPEED sert à 
spécifier la longueur de chaque boucle de tem- 
porisation. Le code de la boucle est tel que, 
lorsqu’une temporisation diminue, l’autre aug- 
mente, et vice versa. 

La temporisation 1 détermine la période pen- 
dant laquelle le moteur est hors tension, et la tem- 
porisation 2 la période pendant laquelle le moteur 
est sous tension. 

Pour les grandes valeurs de SPEED, la première 
temporisation est courte tandis que la seconde est 
longue, ce qui fait tourner le moteur plus rapi- 
dement. De plus petites valeurs de SPEED allonge- 
ront les périodes de mise hors tension du moteur 
lors de chaque cycle, ce qui ralentira sa vitesse. 

L’effet de pulsation que ce programme produit 
peut être observé au moyen du clignotement de 
la DEL de la ligne 1. 


Réponses aux exercices 


1) En supposant que les capteurs sont 
connectés aux lignes 6 et 7 et que le moteur est 
connecté entre les bornes positives des lignes 0 
et 1: 


19 REM BBC VERSION 3,1 

28 DDR=8FES2! DATREG=8FEES 

?DDR=6S:REM ENTREE DES LIGNES 6 ET 7 

avant = liarrière=2 

?7DATREG=avant 

FORI=1TO2800:NEXT:REM TEMPORISATION 

REPEAT UNTIL (?DATREG AND192) 192 

?7DATREG=arrière 

FORI=1TO288B:NEXT:REM TEMPORISATION 

100 IF < ?DATREG AND192)<> 192 THENSS 
ELSE GOTO 108 


8838868 


10 REM CEM 64 VERSION 3.1: 
20 DDR=56579: DATREG=56577 

POKEDDR, 6S3:REM ENTREE DES LIGNES 6 ET 7 
4Q Fu=1:RV=2 
Sa POKE DATREG, FH 
60 FORI=1TO1800:NEXT:REM TEMPORISATION 
70 1F C(PEEK Ç DATREG ) AND192)=192THEN7S 
80 POKE DATREG, RV 
30 FORI=1TO1800:NEXT:REM TEMPORISATION 
1006 1F (PEEK(DATREG) AND192) <> 192THENSO 
118 GOTOU108 


3) En supposant que les capteurs de 40 et de 
70 degrés sont connectés aux lignes 6 et 7 
respectivement et que le chauffe-eau est 
connecté à la ligne 0 : 


REM BBC VERSION 3.3 

DDR=8FES2: DATREG=4FEEO 

?DDR=6S:REM ENTREE DES LIGNES 6 ET 7 

REPEAT 

A$=INKEYS(1) 

?DATREG=1:REM METTRE LE CHAUFFE-EAU SOUS TENSION 
REPEAT 

88 UNTIL(?DATREG AND 192)=0:REM 7 DEG 

90 ?DATREG=G:REM METTRE LE CHAUFFE-EAU HORS TENSION 
188 REPEAT UNTIL(?DATREG AND192)=192 

118 UNTIL AS<>"":REM UNE TOUCHE PRESSEE 


38858838s 


REM CEM 64 VERSION 3.3 

DDR=56579:DATREG=56577 

POKE DDR, SS:REM ENTREE DES LIGNES 6 ET 7 

GET AS 

?DATREG=1:REM METTRE LE CHAUFFE-EAU SOUS TENSION 
1F C(PEEKC(DATREG) AND192) < > @THEN6® 

POKE DATREG, D:REM METTRE CHAUFFE-EAU HORS TENSION 
1F (PEEXK(DATREG) AND192) < > 1S92THEN8@ 

IF A$=""THEN4D 


8838586885 


Tout va bien jusqu'ici 
Piloter des voitures 
miniatures guidées par 
des câbles peut ne pas 
sembler représenter une 
grande récompense 
après tout l'effort investi 
dans ce travail! Mais la 
construction et la 
programmation de ce 
système nous ont fait 
découvrir la construction 
électromécanique, 

et certains problèmes, 
certaines possibilités 
impliqués lorsque l'on 
crée un logiciel dont le 
but est de relier 
l'ordinateur au monde 
réel. (CI. lan McKinnell.) 


Construction LEGO de DAVE WHELAN 


les lignes 0 et 1 : 


REM BBC VERSION 3.2 

DDR=&FES2: DATREG=8FEED 

7DDR=1271REM ENTREE LIGNE 7 

vitesse=SDiavant “liarrière=2 

direction = avant 

REPEAT 

PDATREG=O: REM DFF 

FOR 1=1 TO (108-vitesse) 1NEXT 

PDATREGSd | rect ion 

189 FOR I=1TO1G000:NEXT: REM 

119 UNTIL(?DATREG AND128)=@G:REM INTERRUPTEUR 

128 FORI=1TO1B0@:NEXT:REM TEMPORISATION 

138 TEST POUR CHEVAUCHEMENT DU CAPTEUR 

148 IF(?DATREG AND128)=GTHEN?DATREG=D: 
END 

159 REM ARRIERE LENTEMENT 

169 vitesse=2t:direction=arrière=GOTO 68 


8838888885 


19 REM CBM 64 VERSION 3.2 

28 DDR=56579:DATREG=56577 

3e POKE DDR,127:REM ENTREE LIGNE 7 

4O SP=3D:F We 1 1: RVe2 

So DR=FW 

6e POKE DATREG.@: REM OFF 

78 FORI=1T0(108-SP) 1NEXT 

8e POKE DATREG, DR 

30 FORI=1TOSP:NEXT 

188 1F (PEEKCDATREG) AND1 28) < > GTHENE® 

119 FORI=1TO1B00:NEXT:REM TEMPORISATION 

128 1F(PEEK(DATREG) AND128) =@THENPOKE 
DATREG, @: END 

138 REM RECULER LENTEMENT 

148 SP=21 DR=RV : GOTO6B 


4) En supposant que le premier interrupteur est 


sur la ligne 6 et que le deuxième est sur la 
ligne 7 : 

18 REM BBC VERSION 3. 4 
DDR=8FES21: DATREG=EFESO: DISTANCE=1 
?DDR=63 
REPEAT UNTIL(?DATREG AND64)=0 
?DATREG= 1 
TIME=Q:REM DEMARRER MINUTERIE 
REPEAT UNTIL(?DATREG AND128) =@ 
PRINT"VITESSE="DISTANCE/ (TIME/12@) 
?7DATREG=8 


8835858838 


REM CBM 64 VERSION 3. 4 
DDR=S6S79: DATREG=S6S77 : DS=1 

POKE DDR, 63 

IF (PEEK (DATREG) ANDS4 ) < > GTHENAS 
POKE DATREG, 1 

T=TI:REM DEMARRER MINUTERIE 

1F (PEEK (DATREG) AND1 28) < > QTHEN6S 
PRINT “VITESSE="DS/ ((TI-T) /68) 
POKE DATREG, @ 


88388888s 


2) En supposant que le capteur est connecté à 
la ligne 7 et que le moteur est connecté entre 


1067 


ge css | 


1068 


Former des 


+ 
caracteres 


Nous avons vu comment définir ses propres caractères 
sur le Commodore. Nous donnons ici deux programmes destinés 


au BBC Micro et au Spectrum. 


L’approche par le Spectrum des caractères utili- 
sateur est très pragmatique : 168 octets sur le des- 
sus de la mémoire sont réservés, par le système 
d’exploitation, aux définitions de caractères par 
l'utilisateur. 

Cette zone permet de définir vingt et un carac- 
tères utilisateur, le système d’exploitation ajou- 
tant une valeur CHR$ comprise entre 144 et 164 
pour chaque définition. Les caractères définis 
sont considérés par la machine comme étant 
compris entre « a » et « u » en mode graphique 
(G). La variable système du graphisme défini par 
l’utilisateur (GDU) (adresse 32600) pointe sur le 
premier octet de la zone mémoire réservée, mais 
vous n’avez pas besoin d’effectuer des additions 
compliquées avec cette variable pour trouver 
l’adresse de début d’une définition de caractère. 
La commande LET adresse = USR«A) fournit l’adresse 
du premier octet de la définition du caractère 
entre guillemets. 


Spectrum 


Le programme est la traduction littérale de la 
version du Commodore. Les touches normales 
de contrôle du curseur du Spectrum (touche pré- 
fixée 5, touche préfixée 6, etc.) dirigent le cur- 
seur d’édition, et les touches 6, 7 et 8 non pré- 
fixées sont les touches de commandes : bascule 
d’une position, changement du caractère d’édi- 
tion et placement d’un caractère dans la fenêtre 
texte. Le point d’exclamation est la commande 
de sortie. Une fois vos huit caractères définis, 
vous pouvez sauvegarder la zone du graphisme 
défini utilisateur (GDU) par : 

SAVE«fichierGDU» CODE(USR«A), 168 (USR = UtiliSateuR), 
et la recharger de la sorte : 

LOADufichierGDU» CODE 


La gestion faite par le BBC Micro du gra- 
phisme défini utilisateur est semblable à première 
vue à celle du Spectrum. Les 256 octets compris 
entre &C000 et &0C00 sont réservés aux définitions 
des caractères codés ASCII compris entre 224 et 
225. Si le jeu de caractères est « condensé », ces 
définitions concernent également les codes ASCII 
compris entre 128 et 159, 160 et 191, 192 et 223. 
Si le jeu de caractères est « ventilé », le jeu 
entier de caractères imprimables (depuis CHR$(32) 
jusqu’à CHR$(255)) peut être redéfini, mais au 
prix d’espace de RAM (mémoire vive). Les 
fonctions du programme sont les mêmes 
que pour les versions du Commodore et du 
Spectrum. 

Les touches fléchées contrôlent les déplace- 
ments du curseur. Les touches de fonctions f1 à 
f3 permettent d’accéder aux commandes bascule, 
redéfinition et placer. Le point d’exclamation (!) 
est le terminateur du programme. 


CI. lan McKinnell 


BBC Micro 


Les appels 0$ aux lignes 70 et 180 activent et 
inhibent les fonctions COPY pour permettre l’uti- 
lisation des touches fléchées dans le programme. 
Si vous quittez le programme d’une autre manière 
que par la commande (h, il vous faudra taper 
« "FX40 » pour réactiver les touches d’édition. 

Le BBC Micro vous permet d’utiliser VDU23 
pour définir des caractères, mais il est plus sim- 
ple alors de calculer les adresses appropriées et 
de les soumettre séparément à PEEK et à POKE. 

Vous pouvez sauvegarder vos caractères spé- 
ciaux de la sorte : 

*SAVE «nomfichier» OCOO OCFF 
et le recharger de la sorte : 

*LOAD«» 


19 


RE nest eheoeenee e e 
REM * SPECTRUM * 
REM * GEN. CAR. LIT * 
REM ce oahehtee eee e 
GOSUB 1920: REM initialiser 
FOR ;=0 TO 1 STEP @ 
GOSUB 2500: REM saisie 
GOSUB 3000: REM valider 
GOSUB obéir: REM pointeur 
NEXT j 
STOP 
REM ht too RO OR RO 
REM * initialiser * 
REM  #nototeoheohohahohe ohne tee en 
1020 DIM b(8,8): DIM oui(2,2): 
DIM o(2,7): DIM 1$C8)t: DIM d4$( 
1): DIM t(8,8) 
1100 LET touchenuile=2008: LET 


detcrsr=3500: LET commande=3000: LET 


miseàjour=6508 

1200 REM *+wkinit écran 
1228 LET 1@=4: LET c@=3: LET 11= 
8: LET ci=8: LET o#=16 

1230 LET noir=@: LET bieu=i: LE 
T cyan=5t LET bianc=7 

1240 PAPER cyan: INK noir 


1250 LET z$="caractères utilisateur": 


PRINT AT 1,4528: 
20,4:z$ 
1260 LET 2$=" 76543210": 

10 cO:z$:: PRINT TAB c@+otiz$ 
1270 PRINT AT IB+ci+1,cD:z#3: PR 
INT TAB c@+of:z$ 
1280 FOR 1=10+1 TO 1@+c1 
1290 LET z$=CH$ (i-1@-1)2: LET z 
$=28+" "+28 
1300 PRINT AT l,c@3z$3AT 1, c@tof 
3z$ 
1318 NEXT ! 

1420 REM sekvaleur dpt CUrS. #### 
1440 DATA -1;,+1,0,@ 
1445 DATA @,@,+1,-1 
1450 DATA @,@,+1,-1 
1468 FOR k=1 TO 2: FOR 1=1 TO 4 
1478 READ ok, 1): NEXT 1: NEXT k 
1608 REM ww*init. fenêtre textes 
1620 FOR 1=1 TO 11 
1648 FOR c=1 TO c1 
1669 LET t(1,c)=32 
16898 NEXT c: NEXT 1! 
1800 LET ipos=1: LET cpos=1: LET 
cnsi44: LET e$="A" 
1828 GO SUB 6000 
RETURN 
1999 REM #o#hoteotenh ete Mot Ee 
REM * frappe illésaie * 
REM 2420 eee 2e eee eme me 
BEEP .2,-3: RETURN 
RETURN 
REM 26e he eme bee ee ee ee ee ee 
REM * crsr Ipos, cpos * 
REM oteoeotenteohedeohooh other oh 
LET io=1@+ipos: LET 
cost LET cf=1+b(1p0s, cpos): LET 
d$=" m"Cc#) 
2548 PRINT AT ip,cpt FLASH 154$ 
2600 REM LET t#=SAISIES: IF 1$#<> 
““ THEN GOTO 2608 
2620 LET t#=SAISIES: IF t$="" THE 
N GOTO 2628 
PRINT AT iP,cp5 FLASH G:4$ 
RETURN 
REM ete tete ee ee Oh OR 


ce=ce* 


REM * valider la saisie * 

REM 4266 ete eee eee he 2 

IF t$="!" THEN LET pointeur 
=touchenuile: LET j=2: RETURN 
3240 LET touche=CODE (t#)-7: LET k= 
touche-45: LET pointeur=touchenul le 


3060 IF (touche)=1 AND touche<=4) THEN 


LET pointeur=dptensr: RETURN 
7080 IF (t#>="E" AND t8<="8") TH 
EN LET touche=VAL (t#$)-4 : LET 
pointeur=commande+touche*508: RETUR 
N 
3100 RETURN 
2499 REM ottoman 


3500 REM * déplacer le curseur * 
ZSO1 REM #2 RRO O AOORRO 
3520 LET ny=ipos+o(2r touche) LET 
nx=cpos+o(1, touche) 
3540 IF Cny<i OR ny>11) THEN 
RETURN 
3560 IF 
RETURN 
LET ipos=ny: LET cpos=nx 
RETURN 
REM nt ae ee men eee eme ee ee 


Cnx<1 OR nx>11) THEN 


REM * bascule d’une cellule * 
RM espere ne eee ae eh eme 
LET bs=1-b(ipos, cpos)t LET 
*" (1+bs) 

PRINT AT Ipos+1Q,cpos+c@:d$ 
LET bios; cpos)=bs 

LET Pe=PEEK (mpos+ipos) 

LET pe=pe+(bs#2-1)#(2"(8-cP 


POKE (mpos+iPos), pe 
PRINT AT IG+i1p0s;, c@+c1+33PE 
EK (mpos+ipos);" * 
4228 NEXT | 
430 RETURN 
4499 REM #2 ee HO 
4S0O REM * déf. nouveau car. * 
ASO1 REM #htoitonononootete dote 
4520 PRINT AT 1@+11+3, c@+2: 
FLASH 15"chanser car." 
4530 GOSUB mise à jour 
4S40 PRINT AT 1@+11+4, c@+25 
s“#rappez une touche (a - u)" 
4550 FOR z=1 TO 1 
45S6O LET e$=saisies: IF e$<>"" 
THEN GOTO 4560 
4570 LET e$=sais 
THEN GOTO 4578 
4580 IF (e$<"a" OR e#$>"u") THEN 
GOSUB touchenuile: LET 2=9 
4590 NEXT z 
4600 LET cn=CODE (e$)+79 
4610 IF cn>164 THEN LET cn=cn-3 
ee 
4620 PRINT AT 1@+11+3, c@+25 
FLASH 95" : 
4630 PRINT AT 1@+11+4, c@+25 
“ “ 
GOSUB 6000 
RETURN 
REM  tetototeheseoheohesheshe sente hotte oo 
REM * placer un car. * 
REM ok eh tente eh 
PRINT AT Ipos+10, cpos+c@+ 
OfCARS (cn) 
5040 LET t(ipos, cpos)=cn 
5490 RETURN 
5999 REM étoile 
6000 REM * afficher Un car. 
GABL REM en mete eee ee OR 
6020 LET mpos=UTS (e$)-1: 
INK bieu 
6049 FOR 1=1 TO ci: LET Pe=PEEK 
(mpos+1): LET p=pes LET z$="" 
6060 FOR c=c1 TO 1 STEP -1: LET 
n=INT (pe/2): LET a=pe-2#n 
6980 LET bCl,c)=at LET pe=n 
6108 LET 1$Cc)=" #"(a+1)2 NEXT © 
6120 PRINT AT 1@+1,cD+15183AT r@ 
+lscO+ci+Sipi" " 
6130 NEXT ! 
6140 RETURN 
6499 REM remontent 
6500 REM * MAJ fen. texte _* 
6SO1 REM ho eo on 
6520 FOR 1=" TO 8: LET y=I1@+1 
6540 FOR c=1 TO 8: LET x=c@+c+of 
6560 
6580 
6600 


3 IF et="" 


PRINT AT y,x3CAR$ (tér, c)) 
NEXT c3 NEXT ! 
RETURN 


2e 
21 
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ARE teen heat ee 
REM* BBC Micro + 


ARE M te eee tete ee 


22 REM* GEN CAR. UT. * 


MODE 1 

QX=3 

*FX4, 1 

PROCinitialisation 

REPEAT 

PROCset_commande 
PROCvaliidation commande 
PROCobé i r (COMMANDE } 

UNTIL COMMANDE=SORTIR 
*FX4, 8 

END 

REM entente tente 
DEFPROCinitialisation 

RE Mate 24e tee eee eee ee D D 
DIM BD (8,8) ,C#$ (2,2) 
DIMOFST (2,7) , D$#(1), TX(B, 8) 
D$CD)=" "}DSC1)="m" 
CGEN=40C00-1 

SORTIR=-1 : TOUCHENULLE=@: DPTCRSR=1 : 
BS=2: DF INIR=S: PLACER=4 
REMwtns INIT  ECRANémot 
1D=4:C@=3: 1L=8:CL=8 
CI=CL+3:0F=16 

NOIR=9: ROUGE =1 : JAUNE=2 
BLANC=3: FOND=128 

COLOUR FOND+ROUGE 

COLOUR JAUNE :CLS 
Z$="CARACTERES UTILISATEUR" 
PRINTTAB(4, 1)Z6:TAB(4, 20) Z$ 
Z$=" 76543210" 
PRINTTAB(C@, RD) Z$ 
PRINTTAB(C@+OF, RD) Z$ 
Y=18+1L+1:X=CD 

PRINTTAB(X; Y)Z$ 
PRINTTABCX+OF, Y)Z$ 

FOR 1=1@+1 TO 1@+1L 
Zé=CH$(R-RO—1) 

Z$=2$+" "+28 
PRINTTAB(CO, 1) Z$ 
PRINTTAB(CO+OF, 127$ 

NEXT ! 

COLOUR BLANC 

REMewkVAL. DPT CRSRétonk 
DATA -1,+1,0,0 

DATA @,@,+1,-1 

FOR K=1 TO 2:FO0R L=1 TO 4 
READ VAL. DPTCK,L)2NEXT L,K 
REM####ATTRIBUTION DES TOUCHES##en 
MKEY1"T" 

*KEY2"D" 

MKEYZ"P" 

REM#INIT. FEN. TEXTE#*“ 
FOR i=1 TO 1L 

FOR C=1 RO iL 

TX, C)=32 

NEXT C,1 
1P0S=1 : CPOS=1 :CN=224 

PROC Aff car 

ENDPROC 

ARE Mae en eh 
DEFPROCtouchenul le 


2OB1K  REMam tement ee o HONOR 


SOUND 1;-15; 48, 19 

ENDPROC 
REMrooiinoionntonohnototoh 
DEFPROCPrendre-com 

ARE eee nee eee ee 
1P=10+ 1 POS: CP=CO+CPOS 
PRINTTAB (CP, 1P) 3 
TÉé=GETS 


ENDPROC 
ARE Meet e2 


DEFPROCval i der-com. 

RE Mheoh bte entente nee eee 
COMMANDE =DPTCRSR 

KEY=ASC (T$) -135 

IF KEY<1 THEN COMMANDE=TOUCHENULLE 
IF KEY>4 THEN COMMANDE =TOUCHENULLE 
IF T$="T'THEN COMMANDE =BASCULE 

IF T$="D"THEN COMMANDE=DF INIR 

IF T$="P"THEN COMMANDE=PLACER 

IF T$="! "THEN COMMANDE=SORTIR 
ENDPROC 
REMaotottohhotetotootoh hdd to 


3300 DEFPROCobé i r (commande ) 
LOL REMax meet ORNH 
3320 1F commande=SORTIR THEN 
PROCtouchenul le 

3340 IF commande=OPTCRSR 
PROCdé» 1 acer curseur (TOUCHE) 
3360 IF commande=BS THEN 
PROCbascuier_une_cellule 
3380 IF commande=DFINIR THEN 
PROCdéfinir_un_caractère 
3408 IF commande=PLACER THEN 
PROCeiacer un caractère 
3420 IF touchenulle THEN 
PROCtouchenui le 

3450 ENDPROC 


ARE Meet eee ee ee ee ee ee 
DEFPROCdép | acementcurseur (touche) 
RE Meteo eee ee ee ae me ee 


NY= 1 POS+OFST (2, touche) 

NX=CPOS+OFST(1, touche) 

IF NY>=1 AND NY<=RL THEN 
RPOS=NY ELSE PROCtouchenuli le 
3560 IF NX>=1 AND NX<=CL THEN 
CPOS=NX ELSE PROCtouchenul le 
3600 ENDPROC 

REM#oh abc shraheah entente he ee he 

DEFPROCbascuier_une_celiuie 

RE Me ee nee eee ee 

BS=1-BD <1 POS, CPOS> 

Y=1 POS+RO: X=CPOS+CS 

PRINTTAB(X, Y)D#(BS) 

BD 1P0S, CPOS=BS 

PE=?(MPOS+ 1 POS) 

PE=PE+(BS#2-1)#(2 (B-CPDS)) 

7? (MPOS+ 1 POS) =PE 

PRINTTAB C@+CS, 1@+1 POS)PE 

PROCmise_à_jour_texte 

ENDPROC 

ARE Me eo het he 

DEFPROCdéfinir_caractère 

IREM eee 22e DO 

REPEAT 

PRINTTAB(C@+2, 1@+1L+3) 3 

PRINT" 

PRINTTAB(C@+2, 1@+1L+4) 5 

PRINT" 

PRINTTAB(CO+2, 1@+1L+4) 5 

INPUT "NOMBRE (224-255) “CHNOM 

UNTIL CHNOM223 AND CHNOM 256 

CN=CHNOM 

PROCaffi chase_d'un_caractère 

ENDPROC 

IREM abonner eee eee fe 

DEFPROCPIacer_un_caractère 

PRE Mae eee ee D 

X=CPOS+CO+0F : Y=1 POS+1 9 

PRINTTABCX, Y) 3 CARSCCN) 

TX(CPOS, 1 POS) =CN 

ENDPROC 

RE Mt eee eh one eee 

DEFPROCafficher_caractère 

ARE eee ee D ON 

MPOS= (CN-224) +8+CGEN 

FOR 1=1 TO CL 

PE=? (MPOS+1) :PaPE:Z$="" 

FOR C=CL TO 1 STEP -1 

N=INT (PE/2) :Q=PE-2%N 

BDCR, C)=Q:PE=N 

Z$=D#(Q)+Z#INEXT C 

PRINTTAB (C@+1,1@+12Z$ 

PRINTTAB (C@+CS9, 18+12P 

NEXT ! 

ENDPROC 

RE Me been ne eee ee ee 

DEFPROCmise_à_jour_texte 

REM# oops th 

FOR 1=1 TO IL:Y=1@+1 

FOR C=1 TO IL: X=C@+C+0F 

PRINTTAB(X, Y)CARSCTX(C, 133 

NEXT C,1 

ENDPROC 

Le 1 sisnifie ligne 
et remplace C1: 


le r de l'ansi 
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Au doigt 
et à l'œil 


Cheetah Marketing a déjà réalisé 
bien des extensions destinées au 
Spectrum; sa plus grande réussite 
reste sans doute le synthétiseur 
de parole Sweet Talker. Elle vient 
tout juste de mettre sur le marché 
le RAT, un manche à balai qui 
fonctionne à distance, grâce aux 
infrarouges. 


Les passionnés de jeux d’arcades ne négligent 
aucun détail qui peut améliorer, si peu que ce 
soit, la qualité et la rapidité de leur jeu, surtout 
si leur score final s’en trouve augmenté. C’est 
bien pourquoi la façon dont on guide le dérou- 
lement d’une partie a tant d’importance. Si c’est 
à partir du clavier, il faudra que les touches de 
contrôle soient bien réparties et faciles à utiliser. 
C’est même un aspect auquel les auteurs de logi- 
ciels se doivent d’être particulièrement attentifs. 
Mais un manche à balai, qui est un dispositif de 
commande extérieur à l’ordinateur, est à envisa- 
ger du point de vue du matériel. 

Ce qui importe avant tout, c’est bien évidem- 
ment sa souplesse d’emploi : liberté de mouve- 
ment, rapidité de réaction, etc. Mais la nature 
même de l’objet lui impose certaines limites : lon- 
gueur du câble, taille, forme et emplacement de 
la poignée de commande, position du (ou des) 
bouton(s) de mise à feu. Ce dernier point, par 
exemple, favorise souvent les droitiers. Les 
constructeurs ont depuis longtemps cherché à sur- 
monter ces handicaps, mais aucun ne semble être 
parvenu à réaliser un engin aussi réussi que le 
manche à balai à infrarouges que Cheetah Mar- 
keting a réalisé pour le Spectrum. 

L'objet a reçu le nom de RAT, ce qui veut dire, 
paraît-il, remote action transmitter (transmet- 
teur d’action à distance), mais sans doute est-ce 
plutôt un jeu de mots sur mouse (souris), le 
fameux procédé de guidage dont on se sert avec 
le Macintosh d’Apple et avec plusieurs ordina- 
teurs du même genre. Le RAT a quelque chose 
d’un peu futuriste. Il est long, gris et plat, avec 
un dispositif de contrôle circulaire bleu, un bou- 
ton de mise à feu orange vif; il comporte aussi 
le logo de Cheetah. Deux transmetteurs infra- 
rouges dépassent à l’avant. La première fois que 
vous l’avez entre les mains, vous avez l’impres- 
sion qu’il va en jaillir des flammes bleues. 

Le système dispose également de sa propre 
interface, qui se raccorde au connecteur plat situé 


Diodes à infrarouges 
Elles produisent des 
infrarouges tout comme 
les DEL produisent de la 
lumière. 


Lecteur clavier/ 
modulateur d’impulsions 
Ce dispositif détecte 

chaque touche pressée, 
génère son impulsion k 
codée et la transmet aux ù 
diodes par l'intermédiaire 
du transistor tampon. 


Chris Stevens 


Que la lumière soit 

Les rayons infrarouges sont émis par le transmetteur 
grâce à des diodes; un courant électrique passe dans 
une puce d’arsénure de gallium, dont les molécules 
sont excitées provoquant l'émission de photons. Dans 
le récepteur, c'est l’inverse qui se passe : le courant 


passe dans la diode quand les rayons atteignent 
l’arsénure. Lorsque le dispositif de contrôle du RAT 
enregistre des pressions, les deux diodes du 
transmetteur émettent des impulsions infrarouges 
codées, en un large faisceau, qui atteint le récepteur, 
directement ou après réflexion dans la pièce. 


Matériel Q 
à l’arrière du Spectrum. Cette petite boîte est, de 


surcroît, équipée d’un port d'expansion, en pré- Manche à balai RAT à 
vision d’autres périphériques. Elle n’a qu’un seul Minirarouges destiné au, 
récepteur à infrarouges, installé à l’avant, pour PRE 
communiquer avec le RAT. 

Une petite brochure vous indique comment MRenctionneavec-tous 
vous servir de l’appareil, et précise quels sont les po moe pps 
Ê aie manches à balai Cheetah 
jeux avec lesquels en faire usage (tout programme où Kempston. 
compatible avec le manche à balai de type 
Kempston). Cheetah, qui voit loin, a même pris 
la peine d’inclure dans le texte des routines en Constructeur : Cheetah 
BASIC et en langage machine, de sorte que le Marketing. 

RAT puisse être mis en œuvre avec vos propres 
jeux. 

Les mêmes instructions précisent que le 
système fonctionne jusqu’à 4 m de distance et 
qu’il suffit de le pointer « en direction de 
l’ordinateur ». On commande un mouvement en 
appuyant légèrement sur le dispositif de contrôle. 
Il comporte huit petites « encoches » à sa péri- 
phérie ; en appuyant sur l’une d’elles (ou juste à 
côté), vous sélectionnez une direction particulière 
(nord, sud-ouest, etc.); bref, le tout est un peu 
comparable à une rose des vents. Tandis qu’une 
main tient l’appareil et règle les déplacements, 
l’autre est posée sur le bouton de mise à feu. Vu 
la façon dont le RAT a été dessiné, les deux mains 
peuvent accomplir indifféremment les deux tâches, 
et les gauchers ne sont donc plus désavantagés. 

Le tout doit être équipé d’une pile, qui est pla- 
cée dans une petite cavité juste au-dessous du dis- 
positif de contrôle; il suffit de charger un jeu 
pour démarrer. Aucun signe ne vous permet de 
savoir si le transmetteur fonctionne bel et bien, 
aussi vous retrouverez-vous peut-être collé à 
l’écran.. ce qui vous empêchera de profiter des 
avantages du RAT. Au début, vous vous croirez 
sans doute contraint de ne pas vous éloigner. 
Pourtant, une fois que vous serez certain que le 
système fonctionne, toutes les expériences seront 
possibles. 

Le RAT donne d’excellents résultats, même à 
des distances légèrement supérieures à celles 
qu’indique le constructeur. Il n’est pas besoin 
non plus de le pointer en direction de l’ordina- 
teur. Qu'il soit dirigé vers le plafond ou le plan- 
cher, manipulé dans le dos ou sur le côté, il trans- 
met toutes vos commandes — mais il est alors 
un peu difficile de voir ce qu’on fait. Le joueur 
se voit donc offrir une liberté de déplacement 
beaucoup plus grande. Un gros inconvénient 
cependant : l’appareil n’indique que huit direc- 
tions (haut, bas, droite, gauche et directions inter- 
médiaires). Il aurait été encore plus intéressant 
s’il en avait comporté davantage. 


Chris Stevens 


M, M M, M, Comme le RAT ne comporte aucune partie 


mobile, il est beaucoup moins exposé à la fati- 
gue et au délabrement que connaissent tous les 
manches à balai standard, et devrait donc don- 
ner satisfaction très longtemps. Il est d’ailleurs 
garanti pour une durée de un an. Il est d’un prix 
raisonnable, à peine plus cher qu’un manche à 
balai standard plus l’Interface 2 (mais peut-être, 
il est vrai, avez-vous déjà une Interface 2). Il offre 
en tout cas beaucoup plus de liberté et de préci- 
sion que les autres appareils de ce type. 
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Carte Z80 


Voici reproduit, avec l’aimable autorisation de Zilog Inc., la première partie 
de la carte référence du programmeur Z80. Au-delà de sa complexité, 
il s’agit d’un outil important pour tous ceux qui veulent programmer. 


, 
Li 


ENS. REG. PRINCIPAL ENS. REG. ALT. 


Vecteur Rafraich. 
Interrupt. mémoire 
1 R 


À A’ : 
Se iià 
EE Registres 
D7 Do 
Instruction S Z H PIN N C Commentaires Symbole Opération 
ADD A, s; ADC, s î YO MORAL NTUU y Addition 8 bits ou addition avec retenue soustraction S Drapeau de signe. S = 1 si le MSB 
SUB s; SBC A,s; CPS; NEG ? ? X 1: X V 1 î 8 bits, soustraction avec retenue, comparaison et négation du résultat est 1. 
de l'accumulateur. Drapeau de zéro. Z = 1 si le résultat 
AND s $f + XX 1 XP DD 1 n de l'opération est nul. 
OR 5, XOR s 4 + (Xe 0ù XP 09 20 } Opérations logiques. PIV Drapeau de parité ou de dépassement. 
INC s + Nos tafRa NTM Incrémentation 8 bits. La parité (P) et le dépassement (V) 
DEC s CE XVe me Décrémentation 8 bits. partagent le même drapeau. 
ADD DD, ss # CC NX SRE RIRE Addition 16 bits. Les opérations logiques affectent la 
ADC HL, ss CAR D A Sr di ei Addition 16 bits avec retenue. parité, tandis que les opérations 
SBC HL, ss Et € XuN, Vevmte à Soustraction 16 bits avec retenue. arithmétiques affectent le dépassement. 
RLA, RLCA, RRA ; RRCA e. 7e. IG CR EN UE Rotation accumulateur. Dans le premier cas, P/V = 1 sile 
RLm;RLCm;RRm; î XL PNR. GE Rotation et décalage d'emplacements. résultat est pair, P/V = 0 si le résultat 
RRC m; SLA m; est impair. S'il s'agit de dépassement, 
SRA m; SRL m PIV = 1 si le résultat de l'opération a 
RLD; RRD RE OP OL GE OM AN Rotation de chiffre à gauche et à droite. produit un dépassement. 
DAA tt «+, K TER RME T Ajustement décimal de l'accumulateur. H Drapeau de demi-retenue. H = 1 si 
CPL CRE ONE oi LOTS . Complément de l'accumulateur. l'addition ou la soustraction a produit 
SCF sS. + X-0X ao (1 Retenue. une retenue sur le bit 4 de 
CCF #0 XX 0 LE, SON SE Complément de retenue. l'accumulateur. 
IN r (C) F1. N'AGPRNP EEE Entrée de registre indirect. N Drapeau d'addition-soustraction. 
INIAS INR: OTIR: OTDR x ; x x * : 3 ; } Entrée et sortie de bloc. Z = 0 si B = 0, sinon Z = 1. He 1 a précédente était 
LDI: LDD ‘ , TL ADN Une Instructions de transfert de bloc. P/V = 1 si BC = 0, H&N H DOLRREN FA 
: sinon PIV = 0. let N sont utilisés conjointement à 
LDIR; LDDR X.X XD 100 -D'Ss } l'instruction d'ajustement décimal (DAA) 
CPI; CPIR; CPD; CPDR CE T7 ET ON Instructions de recherche de bloc. Z = 1 si A = (HL), pour corriger le résultat en format BCD 
sinon Z = 0. suivant l'addition ou la soustraction 
LD A, I, LD A,R î F XPOLeRUIFF 010 PIV = 1 si BC = 0, sinon P/V = 0. utilisant des opérandes en format BCD. 
Le contenu de la bascule d'interruption (interrupt. Le} Drapeau de retenue/lien. C = 1 si 
BIT b,s X. 4 Kat Re flip-flop/IFF) est copié dans le drapeau P/V. l'opération a produit une retenue du MSB 
L'état de bit b d'emplacement est copié dans le drapeau Z. de l'opérande ou du résultat. 
î Le drapeau est affecté suivant le résultat 
de l'opération. 
. Le drapeau n'est pas modifié 
par l'opération. 
LDr,r rer r f 0 Le drapeau est remis à zéro 
LD r,n r-n r 110 par l'opération. 
-n— 1 Le drapeau est mis à un par l'opération. 
LD r, (HL) t+— (HL) r 110 X Le drapeau est indifférent. 
LD r, (IX + d) r+—{IX + d) 011 101 V Drapeau P/V affecté suivant le résultat 
FE CAN de dépassement de l'opération. 
+ d— PIN Drapeau P/V affecté suivant le résultat 
LD r,(IY + d) r+—(IY + d) 111 101 de parité de l'opération. 
r 110 t L'un des registres d'UC : A, B, C, D, E, H 
—d— ou L. 
LD (HL), r HbD+r 110 s N'importe quel emplacement 8 bits pour 
LD (IX + d),r (IX + d)+r o11 tous les modes d'adressage autorisés par 
110 cette instruction. 
+ d— ss N'importe quel emplacement 16 bits pour 
LD (IY + d),r (Y + d)+r 111 tous les modes d'adressage autorisés par 
110 cette instruction. 
-d— N'importe lequel des deux registres 
LD (HL), n (Hb)+n 110 110 d'index IX ou lY. 
-n— R Compteur de rafraîchissement. 
LD (IX + d),n (IX + d)+-n 011 101 n re 8 bits comprise dans l'intervalle 
110 110 < 0, >. 
+d— nn Valeur à 16 bits comprise dans l'intervalle 
+-n— < 0,65535 >. 


LD(IY + dj,n  (IY + d)+-n 


LD A, (BC) 
LD A, (DE) 
LD A, (nn) 


A + (BC) 
À + (DE) 
A+ (nn) 


LD (BC), A 
LD (DE), A 
LD (nn), A 
LD A,1 
LD A,R 
LDI,A 
LDR, A 


Notes : 

r,r’ représentent n'importe lequel des registres A, B, C, D, 
ERE 

IFF, contenu de la bascule d'interruption, est copié dans le dra- 
peau P/V. 


1072 


111 101 
110 110 
- d— 
-n-— 

001 010 
011 010 
111 010 
+-n-— 
-n-— 
000 010 
010 010 
110 010 
n— 
-n— 

101 101 
010 111 
101 101 
o11 111 
101 101 
000 111 
101 101 
001 111 


= drapeau non affecté; 0 = drapeau à zéro; 
= drapeau mis; X = drapeau inconnu; 
1 = drapeau affecté selon le résultat de l'opération. 


Ro ? 
Variations sur une tortue 


Notre étude du langage LOGO nous a appris comment définir 
des procédures pour effectuer des séquences de commandes. 
Voyons comment obtenir plusieurs effets avec la même procédure. 


Avec LOGO, un mot, par exemple «taille», peut 
être utilisé de trois manières. Afin de les distin- 
guer, LOGO utilise trois notations : TAILLE, :TAILLE 
(que l’on dit « taille apostrophe »), (TAILLE (que 
l’on dit « taille guillemets »). 

Lorsque LOGO rencontre le mot TAILLE non 
précédé d’une pon£tuation, il le considère comme 
un nom de procédure et effectue la séquence de 
commandes présénte dans la définition de TAILLE. 

TAILLE indique/la valeur contenue dans le nom 
de la variable. Lorsque LOGO rencontre :TAILLE, 
il restitue la valeur associée au nom. 

(TAILLE fait référence aux noms de varïäbles & 
de procédures. Ainsi (TAILLE est utttisé pour f£z 
référence à une variable TAILLE renvoié à la 
valeur attribuée à fâriable. Vous ren ne 5 
qu’il n’y a pas-dé guillemets après le n4 ë 
du nom étant sistaléé par un bla ; 


Technology) ne coïncide pas te 
utilisation aved cette notation. 
RS | IT, EFAACE et PO, 


qu’elle meet 
céduré. Le LOGO! dè 


commandes. 

P@ur utiliser une 
avohñs définies jusqu'ici, i 
nom, exactement dé la mêmé 


TQ RTUE. Cependant, | d’autres co 
qh’AVANCE, supposen des informäti 

entaires pour être ütilisées. 

Le“mot AVANCE tout $eul est dépourvi 
fication, à e valeur doit lui être assoGée pour 
que LOGO puisse. exécüter la commande\sSi les 
procédures compreïraight.des noms de variäbles; 
il serait possible de passèrles valeurs voulues € 
de varier ainsi les effets obtenus à l’appel des 
procédures. 

Reprenons la procédure que nous aVons défi- 
nie dans un article précédent pour tracer un cäà 


POUR CARRÉ 
RÉPÈTE [AV 50 DR 90] 
FIN 


Cette procédure tracera un carré de 50 unités 
de côté. Elle serait cependant beaucoup plus utile 
si elle pouvait dessiner un carré dont on pour- 
rait choisir les dimensions. Il suffirait alors 


d’entrer au clavier la valeur retenue. Pour modi- 
fier CARRE afin qu’elle accepte cette saisie, utili- 
sez l’éditeur pour remplacer la valeur figée 50 par 
la variable (CÔTÉ et ajoutez :CÔTÉ à la ligne 
de titre. 

Notre procédure sera alors : 


POUR CARRÉ :CÔTÉ 1 
RÉPELE4AV :CÔTÉ 90] 
j 


A l’appel de la procéduxe, on donnera une 
à la variable (CÔTÉ. Esdayez avec CARRÉ 4, 
pour voir commerk variera la taille 


it qu’une 
qu’eNe doit 


ef prend 
a restituer én saisie 


nrocédure uklise la même varia- 


4 
eYra faire app} à une qutre case. 
ée variable 


a procédure MAI- 

ne solution 
Elle peut êtré 
e saisir différentes 


CARRÉ :GRAND 
AV :GRAND DR 30 
RL:GRAND 
GH 30 AR :GRAND 
FIN 
POUR CARRÉ :TAILLE 
RÉPÈTE 4[AV :TAILLEÆR 90] 
FIN 
POUR TRI :CÔTÉ 
RÉRÈTE 3IAVSCÔTÉ DR 120] 
CARRÉ est exécuté, AV TAILLE devenant AV%0. Une 
procédure similaire est suivie à l’appel de TRI. 


Voici une procédure qui trace des polygones, 
le nombre des côtés étant donné comme entrée : 


EX Mots de passe 
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POUR POLY :CÔTÉS | 
RÉPÈTE :CÔTÉS [AV 80 DR 360/ :CÔTÉS] 
FIN 


En utilisant cette procédure avec une entrée, 
POLY 3 tracera un triangle; POLY 4, un carré, etc. 
Cependant, pour tous les polygones tracés par 
cette procédure, les côtés auront 50 unités de 
longueur. 

Nous avons utilisé trois noms de variables, 
«GRAND, «TAILLE et «CÔTÉ. Nous aurions pu prendre 
le même no pour les trois, puisque les Varia- 
bles sont Jocales pour les procédures qui les 
utilisent. 

Pour comprendre comment fonctionnent ces 
procédurés, voyons ce qui se passe lorsque 


gne la valeur 30 à la variable (GR 
dans MAISON. La première 
donc maintenant équivalente à 
variable (TAILLE-däns CARRÉ reçoit À 
valeur 30 
Une procédure plus générale 


POLY 530 tratera me 
les côtés ont 30 po 


« globales ». Elles sont très utiles 
niquer des informations entre les ‘procé 
Leur inconvénient.est de rendre plus-di 
dépistage des erreurs: 

La commande FAIRE est utilisée pour assigner 
des valeurs à des variables globales. FAIRE (CÔTÉ 3 
affecte la valeur 3 à la variable «CÔTÉ. FAIRE 
(CÔTÉ :CÔTÉ + 1 incrémente d’une unité la väleur de 
(CÔTÉ. La signification exacte de la syntaxe du 
deuxième exemple est la suivante : trouver la 
valeur de la variable (COTE, lui ajouter 1 et remet- 
tre le résultat dans la variable (CÔTÉ. Dans les 
deux cas FAIRE suppose deux entrées, le nom de 
la variable et la valeur à lui assigner. 

Pour résumer les notions de programmation 
LOGO que nous avons vues dans cet article, nous 
avons créé des procédures de dessin de spirales. 
La procédure principale s’appelle EOSPI. Elle sup- 
pose trois entrées, la longueur initiale de la ligne 
à tracer, l’angle à couvrir à chaque tournant de 
la spirale et un facteur d’échelle affectant la lon- 
gueur initiale. Différents ensembles de données 
en entrée seront utilisés pour obtenir plusieurs 


effets. Nous avons essayé 70 283 0.9, 70 143 0.6 et 
20 243 1,05. Essayez d’autres jeux de valeurs pour 
avoir d’autres effets. 

FINENROULE est une nouvelle commande. Elle 
arrête l’enroulement de l’écran lorsque la tortue 
atteint les limites de ce dernier. Un message 
« hors champ » est alors transmis. L’effet 
d’enroulement donne souvent des résultats gra- 
phiques intéressants. Mais pour cette procédure, 
il gâche l’effet de spirale. C’est pour ce genre de 
cas qu’existe cette commande, afin de l’inhiber. 

à procédure p pa QSP à même 
ligne de manière répétitive. La longueur de la 


tournant selon un angle déter- 
en dernier lieu le facteur 


OS?! provoque u 
miné et modifie 


destiné à faire s’exécuter la procédure 
un grand nombre de fois. Si vous voulez l’arrê- 


(ACCROISSEMENT change de vale 


La . 

Réponses aux exercices 
1) Les puzzles Tangram 
L'homme assis, l’homme qui se penche 
| et le chat, toutes ces formes utilisent 
| l’autre côté du parallélogramme pour le 
chien de la semaine dernière. Pour 
retourner un motif avec LOGO, il suffit de 
changer toutes les commandes DROITE en 
GAUCHE, et vice versa. Aussi, au lieu de : 


POUR PAR 

REPETE 2 CAV 25 DR 45 AV 35 DR 135] 
FIN 
nous aurons son image en miroir : 


POUR PAR 
REPETE 2 CAV 25 GH 45 AV 3S GH 135] 


FIN 

Toutes les autres procédures de dessin de 
silhouettes sont semblables à celles expliquées 
ici. 


L'homme qui court 
POUR COURIR 
DEPLACEMENT1 TRI1 DEPLACEMENT2 PAR DEPLACEMENT TRIS 
DEPLACEMENT4 TRIS DEPLACEMENTS CARRE DEPLACEMENTES TRII 
DEPLACEMENT7 TRI2 
DEPLACEMENT 
FIN 
POUR DEPLACEMENT1 
GH 45 
FIN 
POUR DEPLACEMENT2 
CL AV 25 DR 135 AV 17.5 GH 45 CB 
FIN 
POUR DEPLACEMENTS 
CL AV 75 DR 90 CB 
FIN 
POUR DEPLACEMENT4 
CL DR 9@ AV 25 DR 90 CB 
FIN 
POUR DEPLACEMENTS 
CL AV SO DR 135 AV 50 GH 135 CB 
FIN 
POUR DEPLACEMENTS 
CL DR 135 AV 21 DR 135 AV 25 GH 90 AV 50 
GH 90 AV 25 DR 90 CB 
FIN 
POUR DEPLACEMENT7 
CL AV 25 DR 135 AV 71 DR 45 AR 35 CB 
FIN 
POUR DEPLACEMENTS 
CL AV 35 GH 92 AV 25 DR 45 AV 17.5 GH 45 
AV 25 DR 135 CB 


| FIN 


L'homme assis 
POUR ASSIS 
DEPLACEMENT1 TR1 DEPLACEMENT2 TRI2 DEPLACEMENTS TRIS 
DEPLACEMENT4 TRI1 PAR1 DEPLACEMENTS CARRE DEPLACEMENTE 
TRI3 DEPLACEMENT7 
FIN 
POUR DEPLACEMENT 1 
GH4S 
FIN 
POUR DEPLACEMENT2 
CL AV 25 GH 45 AV 17.5 DR 90 CB 
FIN 
POUR DEPLACEMENTS 
CL AR 15 GH 90 CB 
FIN 
POUR DEPLACMENT4 
CL AV 50 DR 45 AV 25 DR 90 CB 
FIN 
POUR DEPLACEMENTS 
CL AV 25 GH 45 
FIN 
POUR DEPLACEMENTE 
CL AR 50 GH 98 
FIN 
POUR DEPLACEMENT7 
CL AR 21 DR 135 AR 50 DR 90 AV 35 GH 930 
CB 


L'homme courbé 


POUR COURBE 
DEPLACEMENT1 TRI1 DEPLACEMENT2Z PAR1 DEPLACEMENTS TRIZS 
DEPLACEMENT4 TRIS DEPLACEMENTS TRI1 DEPLACEMENTS TRI2 
DEPLACEMENT7 CARRE DEPLACEMENTS 
FIN 
POUR DEPLACEMENT 1 
GH 90 
FIN 
POUR DEPLACEMENT2 
CL AV 25 DR 135 AV 30 CB 
FIN 
POUR DEPLACEMENTS 
CL GH 45 AV 35 GH 135 AR S0 CB 
FIN 
POUR DEPLACEMENT4 
CL DR 930 AV 59 GH 135 CB 
FIN 
POUR DEPLACEMENTS 
CL DR 90 AV 58 GH 135 AV S DR 90 CB 
FIN 
POUR DEPLACEMENTE 
CL DR 9@ AV 25 DR 45 AV 7.5 DR 45 AR 35 
cB 
FIN 
POUR DEPLACEMENT7 
CL AV 3S DR 155 AV 7.5 GH 45 AV 55 DR 45 
CB 
FIN 
POUR DEPLACEMENTS : 
CL GH 45 AV 36 DR 45 AV 56 GH 135 AV 5 
GH 45 AR 25 CB 
FIN 


Le chat 
POUR LE. CHAT 
DEPLACEMENT1 TRIZS DEPLACEMENT2 CARRE DEPLACEMENTS TRI1 
DEPLACEMENT4 TRI1 DEPLACEMENTS TRIZS DEPLACEMENTE PAR1 
DEPLACEMENT7 TRIZ2 DEPLACEMENTS 
FIN 
POUR DEPLACEMENT1 
CL AV 50 DR 98 
FIN 
POUR DEPLACEMENT2 
DR 179 
FIN 
POUR DEPLACEMENTS 
CL DR 90 AV 25 
FIN 
POUR DEPLACEMENT4 
DR 180 
FIN 
POUR DEPLACEMENTS 
CL DR 90 AV 25 GH 82 AV 5Q DR 45 AV 58 
DR 90 CB 
FIN 
POUR DEPLACEMENTS 
GH 155 
FIN 
POUR DEPLACEMENT7 
CL GH 169 AV 35 CB 
FIN 
POUR DEPLACEMENTS 
CL AV 35 GH 45 AV 21 DR 135 CB 
FIN 


Bios © "SSSR 


Vitesse ou présentation ? 
Tout ce qui contribue à 
faire s'exécuter un 
programme rapidement nuit 
à sa présentation et à sa 
compréhension. Le bon 
compromis n’est pas 

facile à trouver 

(CI. Apple.) 


3 
Æ 
xs 
+28 
258 
23 
D] 
=] 
a 
Las 
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Notre cours s’est consacré jusqu'ici à la programmation structurée. 
Les méthodes décrites permettent des programmes plus faciles 
à développer, mais n’accélèrent pas l’exécution du BASIC. 


Pour que les programmes s’exécutent vite et occu- 
pent moins de place mémoire, il est souvent 
nécessaire de sacrifier la clarté de présentation. 
Il faut savoir que lorsqu'on optimise un pro- 
gramme, tout ce qui contribue à le faire s’exécu- 
ter plus vite le rend inévitablement plus difficile 
à lire, à comprendre et à mettre au point. 

La lenteur inhérente aux langages interprétés, 
tels que le BASIC, entraîne parfois une lenteur 
inacceptable d'exécution et contraint à une accé- 
lération du programme. La manière la plus effi- 
cace de pallier ces défauts est de compiler les pro- 
grammes BASIC. Mais très peu de micros 
comportent de vrais compilateurs BASIC. Il existe 
bien des compilateurs sur disque et cassette sur 
le marché, mais la plupart concernent exclusive- 
ment le BASIC avec nombres entiers et supposent 
un formatage préalable spécial du programme. 

Le compilateur occupe de l’espace mémoire 
utilisateur et prend d’autant plus de place qu’il 
est plus efficace et complet. De manière générale, 
pour les micro-ordinateurs personnels, la com- 
pilation n’est conseillée que pour des program- 
mes sans erreurs. 

Les accès aux fichiers ralentissent considéra- 
blement l’exécution du programme et constituent 
même la première cause de la lenteur du BASIC. 
Pour un programme qui effectue fréquemment 
des lectures/écritures sur disques ou cassettes, les 
attentes sont inévitables. L’accès à un enregistre- 
ment d’un fichier à accès direct sur disquette 
prend en moyenne un quart de seconde. L’accès 


aux données de fichiers série prend davantage de 
temps. Les accès cassette prennent de manière 
générale plus de temps que les accès disque. 

Si ces temps de latence posent des problèmes, 
essayez de réduire le nombre d’accès et de lire 
plus de données à la fois. En les sauvegardant en 
mémoire vive, constituez, également sur fichier, 
des sauvegardes de mises à jour jusqu’à la fin de 
la session. Les programmes interactifs posent 
souvent des problèmes dans la mesure où l’uti- 
lisateur doit attendre plusieurs secondes devant 
son écran. Une solution partielle consiste à réor- 
ganiser le programme de sorte que les fichiers 
soient lus et écrits pendant que l’utilisateur fait 
autre chose. 

Une autre cause de lenteur est l’arithmétique 
des nombres réels. La présence de décimales fait 
que la recherche en mémoire d’un nombre réel 
et son traitement supposent beaucoup plus de 
cycles machine que pour un nombre entier. 

Les programmes qui comportent beaucoup 
d’arithmétique justifient largement que l’on rem- 
place toutes les variables par des variables entiè- 
res (SOMME, par exemple, sera remplacé par 
SOMM%). On peut ainsi gagner jusqu’à vingt pour 
cent de temps, même sur des programmes relati- 
vement numériques. Les applications grandes 
mangeuses de nombres peuvent, quant à elles, 
gagner jusqu’à cinquante pour cent de temps. 

Écrire un algorithme plus rapide est une des 
meilleures manières d’accélérer un programme. 
Nous vous avons déjà donné des références pour 
vous procurer des algorithmes tout prêts. 
Essayez-les et soyez à l’affût des nouveaux algo- 
rithmes que publient régulièrement les revues spé- 
cialisées. La création d’algorithme est une ques- 
tion de créativité et de perspicacité. Le BASIC 
comporte généralement de nombreuses fonctions 
incorporées (telles que INSTR, SGN, LOG, etc.). 

La vitesse de ces dernières résulte de leur écri- 
ture en code machine et du fait qu’elles utilisent 
les meilleurs algorithmes existants. Les fonctions 
définies par l’utilisateur, mises en œuvre par la 
commande DEF FN, s’exécutent également très 
rapidement. Cette commande est surtout utile 
pour des programmes avec calculs répétés ou 
séquences répétées de manipulations de chaînes. 
La commande DEF FN remplace alors un appel de 
sous-programme qui est beaucoup plus lent. 

Écrire les routines en code machine les rend 
généralement plus rapides. Les langages interpré- 
tés traduisent en code machine les lignes de pro- 
gramme au fur et à mesure qu’ils les rencontrent, 
et pendant l’exécution du programme. 


L'écriture en code machine évite cette phase 
de traduction. Malheureusement, le langage 
d’assemblage est beaucoup plus difficile que le 
BASIC. Le coût en temps et en efforts pour 
apprendre et bien posséder le langage d’assem- 
blage n’est pas compensé par ce que l’utilisateur 
moyen peut en retirer. Cependant certains pro- 
grammes, comme ceux qui utilisent du graphisme 
animé, ne pourraient pas être écrits en BASIC 
seulement. 

Il y a beaucoup d’autres manières de gagner 

du temps de traitement : utiliser une variable au 
lieu d’un nombre (par exemple, MAX au lieu de 
2675) pour un accès plus rapide aux valeurs, et 
spécialement dans les boucles; utiliser différen- 
tes lettres pour commencer les noms de variables, 
et prendre ces lettres à intervalles réguliers dans 
l’alphabet ; utiliser des lignes d’instruction mul- 
tiples et espacer régulièrement les numéros de 
lignes (de 10 en 10 par exemple); avec les bou- 
cles FOR..NEXT, et si l’interpréteur le permet, se 
passer de la variable du compteur d’itérations; 
à l’intérieur d’une boucle, essayer d’éviter de 
recalculer sans cesse la même valeur, maïs la cal- 
culer en dehors de la boucle pour l’incorporer en 
tant que variable. 
L’arithmétique des entiers permet de gagner du 
temps, mais aussi de la place mémoire. Là où il 
faudrait peut-être 4 ou 5 octets pour sauvegar- 
der un nombre réel, il n’en faut que deux pour 
un entier. D’autres gains de vitesse représentent 
aussi des gains de place : l’utilisation de fonctions 
incorporées ou de fonctions utilisateur supprime 
du code, tout comme l'écriture en langage 
d’assemblage et l’utilisation de lignes d’instruc- 
tions multiples. La compilation a tendance à 
accroître la taille des petits programmes et ne per- 
met de gagner de l’espace mémoire que pour les 
grands programmes. 

La suppression des REM libère de la place, de 
même que l’utilisation de chaînes texte plus cour- 
tes pour les messages. Sauvegarder hors du pro- 
gramme de gros pavés de texte dans des fichiers 
les maintient à l’écart lorsqu'ils ne sont pas néces- 
saires. Retirez autant que cela est permis les espa- 
ces des lignes et utilisez des numéros de lignes et 
des noms de variables plus courts. Si un tableau 
doit être dimensionné et que sa taille exacte est 
connue, ne faites pas d’approximation. Attendez 
de pouvoir disposer de l’information nécessaire 
pour le dimensionner à l’aide d’une variable, 
par exemple : 


10 INPUT«Nombre d'éléments de cette catégorie?». ÉLÉMENTS % 
20 DIM ARRAY %IELEMENTS)} 


Cela s’appelle « dimensionnement dynamique ». 
Une autre solution revient à accroître la place 
réservée au BASIC en mémoire vive. Cela 
s’obtient par l’intermédiaire de commandes tel- 
les que HIMEM. Ces commandes changent la zone 
mémoire utilisateur réservée aux programmes et 
aux variables. Le rôle normal de HIMEM consiste 
à sauvegarder des programmes en code machine 
de manière à les mettre à l’abri d’une éventuelle 
réécriture. La même commande peut cependant 
permettre d’accéder à des positions mémoire sup- 


plémentaires en les libérant de leur affectation 
normale à la mémoire d’écran. Si l’affichage est 
sans importance, c’est là un bon moyen de gagner 
1 K de mémoire. Si l’on ne peut modifier HIMEM, 
la mémoire d’écran peut néanmoins être utilisée 
par le biais de PEEK et de POKE s’adressant direc- 
tement aux positions mémoire de l’écran. 

Si toutes ces méthodes ne suffisent pas, on peut 
encore avoir recours à la commande CHAIN, dont 
disposent de nombreux BASIC. CHAIN permet à un 
programme de passer le contrôle à un autre pro- 
gramme. Certains BASIC présentent la commande 
COMMON qui transmet certaines variables et leurs 
valeurs courantes au programme suivant. Sur les 
micro-ordinateurs personnels, CHAN, lorsqu'elle 
existe, est généralement une commande très sim- 
ple, qui permet de transmettre la totalité ou une 
partie des variables du premier programme au 
deuxième. 

Si les programmes sont écrits selon la pro- 
grammation structurée, les sous-programmes 
devraient pouvoir être écrits et testés séparément. 
Leur exécution peut également être chronométrée 
séparément. Essayez le simple programme sui- 
vant de chronométrage : 


100 REM Utilisez cette première partie pour 

105 REM affecter des valeurs aux variables de 

10 REM la routine (n'oubliez pas de 

115 REM dimensionner les tableaux et de leur 

120 REM attribuer des valeurs virtuelles). 

25 REM Ce programme est en BASIC BBC. TEMPS 
130 REM est une variable pour le temps 

135 REM dont la valeur en centièmes de 

140 REM seconde, est donnée par l'horloge du 

145 REM système. 

200 DÉBUT =TEMPS 

210 GOSUB 2000:REM appel de la routine chronométrée. 
220 FIN=TEMPS 

230 PRINT « L'exécution a pris »:(FIN-DÉBUT)/100:« secondes » 
240 END 


Cette routine permet d’essayer différents algo- 
rithmes et diverses façons d’accroître la vitesse. 


LE 
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Liens d’index 

Le symbole BASE — initialisé 
5050 — est l'adresse du 
premier octet dans un 
tableau de valeurs. 
L'instruction de mode 

d’ pepieaarnes indexé, LDA 


par 


BASE 


Kevin Jones 
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X, prend la valeur de 

Ë et lui additionne le 
contenu du registre X pour 
fournir l’adresse effective 
de l’octet dont le contenu 
est chargé dans 
l'accumulateur. Si cette 
instruction est à l’intérieur 
d'une boucle dont X est le 
compteur, tout le tableau 
est accessible, octet par 
octet, en séquence. 
Puisque *X est un registre à 
16 bits, la boucle peut 
parcourir la totalité de 
l'espace mémoire ($0000-$FFFF 
dans un système 8 bits 
comme le 6809). 


TABLEAU DE SYMBOLES 


Changement d'adresse 


Examinons maintenant comment les deux registres d’index, X et Y, 
sont utilisés dans l’adressage indexé. Nous illustrons la valeur de 
l’indexation en nous référant à plusieurs exemples de programmes. 


L'originalité de l’ordinateur à programme stocké 
résidait dans le fait que, en stockant le pro- 
gramme au même endroit que les données sur les- 
quelles il doit opérer, celui-ci pouvait se modi- 
fier lui-même en cours d’exécution. Son rôle prin- 
cipal n’était pas de modifier les instructions elles- 
mêmes, mais de changer les adresses où les ins- 
tructions prennent leurs données. Imaginons que 
nous ayons accès à un tableau de plusieurs mil- 
liers de nombres et que nous devions donner des 
instructions distinctes pour chacun parce que cha- 
que instruction ne pourrait se référer qu’à une 
adresse inchangeable. 

Ce problème fut grandement facilité par 
l’introduction du concept de modification 
d'adresse. 

De la sorte, la même instruction pouvait être 
répétée autant de fois qu’on le voulait et renvoyer 
à des adresses différentes où étaient stockées les 
données, en utilisant une variable dans un regis- 
tre pour modifier l’adresse. Nous utilisons tout 
le temps ce type de concept dans les programmes 
BASIC. 


Par exemple : 


FOR 1=1 TON 
PRINT TABLE(I) 
NEXT | 


Dans ce cas, la même instruction PRINT se 
réfère à des données différentes chaque fois 
qu’elle est utilisée, en modifiant l’article de don- 
née de base (TABLE) et en utilisant une valeur 
indexée (!), qui est changée chaque fois qu’elle 
est utilisée. 

Le principe fondamental de l’adressage indexé 
est que le contenu du registre d’index est addi- 
tionné à l’adresse de base donnée dans l’instruc- 
tion pour fournir l’adresse effective. Si cette 
instruction a lieu à l’intérieur d’une boucle, 
l’ajustement au registre d’index peut être effec- 
tué également dans la boucle. 

Le 6809 a non seulement deux registres pour 
cela, les registres X et Y, mais encore deux autres, 
S et U. Dans des circonstances spéciales, il est 
possible d’utiliser aussi le compteur de pro- 
gramme. Pour rendre le sujet de l’adressage 
indexé encore plus complexe, il y a divers modes 
d’indexation. Cependant, ceux-ci couvrent pres- 
que tous les besoins de la programmation. Nous 
emploierons dorénavant l’adressage dans tous 
nos programmes. 

L’adressage indexé est indiqué par l’addition 
de XX à la zone opérande — si le registre utilisé 


est X, bien entendu. La forme générale d’une 
instruction indexée est donc : 


Opc Décalé, Registre d'index 
LDA  TABLEI,X 
STA  TABLE2,Y 


Dans bien des situations, le décalé est nul, 
auquel cas il peut être omis. Par exemple : 


Opc Registre d'index 
LDA XX 
STAY 


Supposons que nous ayons un tableau de 
64 valeurs à 8 bits stockées en $300 et que nous 
voulions accéder aux octets en séquence. Nous 
pouvons définir l’adresse de base et réserver de 
l’espace pour le tableau utilisant les directives : 


ORG $3000 
TABLE RMB 64 


Ces instructions mettent le compteur de pro- 
gramme à 5300, définissent TABLE comme com- 
mençant à 5300, et réservent les 64 octets sui- 
vants. Nous avons dès lors accès aux octets en 
utilisant la suite du code : la nouvelle directive 
ORG signifie que notre code sera stocké dans une 
autre partie de mémoire que nos données. Quand 
on commence à utiliser l’adressage indexé, c’est 
une précaution raisonnable pour éviter à une bou- 
cle de sortir du contrôle et de causer un « écrase- 
ment » du programme. 


ORG $1000 
COUNT FCB 0 
\ LDX #0 
LOOP LDA TABLE X 


Changeons maintenant la valeur dans le regis- 
tre x : 


TFR X,D 
ADDD #| 
TFR D,X 


C’est une manière maladroite d’incrémenter 
X, quoiqu'’elle puisse être utile en cas d’incré- 
mentation ou de décrémentation de nombres 
supérieurs à 2. Le dernier fragment de code incré- 
mente le compte et s’assure qu’il n’est pas égal 
à 64 (auquel cas le programme se termine et met 
fin à la boucle) : 


INC COUNT 
LDB COUNT 
CMPB #64 
BLT LOOP 


Il y a de nombreuses manières d’améliorer 
l’efficacité de ce code. L’une des plus utiles est 
le mode d’auto-incrémentation. 

L’instruction : 


LDA TABLE,X+ 
aura pour effet d’incrémenter automatiquement 


la valeur en X après usage. Si nous avons un 
tableau de valeurs 16 bits, nous écrivons : 


LDA TABLE,X+ + 


qui a pour effet d’incrémenter le registre X de 2. 
Notre boucle de programme initiale est à présent 
considérablement améliorée : 


LOOP LDA TABLE,X+ 
INC COUNT 
LDB COUNT 
CMPB #64 
BLT LOOP 


Une autre solution avantageuse consiste à par- 
courir toutes les valeurs du tableau dans l’ordre 
inverse, peut-être en utilisant le mode d’autodé- 
crémentation. Cette solution aboutit à une valeur 
finale nulle dans le registre X, et comme l’auto- 
décrémentation d’un registre d’index met auto- 
matiquement les drapeaux dans le registre CC, 
nous pouvons tester directement la fin de la bou- 
cle, sans avoir à utiliser une instruction CPM. Le 
même effet peut être obtenu en chargeant le regis- 
tre d’index avec une valeur négative et en l’incré- 
mentant jusqu’à zéro. Chaque fois que l’instruc- 
tion d’auto-incrémentation est exécutée, elle met 
les drapeaux de CC pour montrer les résultats de 
l’incrémentation. Si l’on obtient un zéro, le dra- 
peau de zéro est mis; s’il y a une retenue, c’est 
le drapeau de retenue, etc. 

Il faut cependant rappeler que, en général, il 
n’est pas toujours suffisant de tester seulement 
les accumulateurs. Aussi, puisque la plupart des 
programmes risquent de comporter un traitement 
entre l'instruction d’incrémentation/décrémenta- 
tion et le test, il est peu probable que le registre 
CC demeure inchangé entre l’action et le test. 

Si nous décidons de ne pas parcourir le tableau 
à reculons, on peut néanmoins conserver l’idée 
du compte à rebours afin de terminer la boucle 
à zéro. En mode d’autodécrémentation, il ne faut 
pas oublier que la décrémentation s’effectue 
avant le calcul d’adresse, tandis qu’en auto- 
incrémentation le registre est incrémenté après 
que l’adresse a été calculée. Ainsi, si X contient 
7 et TABLE commence à $100, l’instruction LDA 
TABLEX+ chargera l’accumulateur à partir de 
l’adresse $107, puis incrémentera X de 7 à 8. LDA 
TABLE,-X (notez le signe moins avant le nom de 
registre), par contre, décrémentera X de 7 à 6, 
puis chargera l’accumulateur avec la valeur pro- 
venant de l’adresse $1006. 

En parcourant le tableau à reculons et en 
tenant le compte dans le registre B, notre boucle 
devient : 


LDX #64 
LDB #64 
LOOP LDA TABLE, -X 


Langage machine 


DECB 
BGE LOOP 


Le premier de nos deux programmes montre 
une boucle directe parcourant un tableau de 
valeurs à 8 bits, dans lequel nous comptons le 
nombre de valeurs négatives. Le compte dans 
l’accumulateur B est également utilisé comme 
décalé d’une valeur fixe dans X. Le second pro- 
gramme montre les deux registres d’index utili- 
sés ensemble, avec un décalé nul. Il fait une copie 
d’une chaîne de caractères à partir d’un empla- 
cement vers un autre emplacement, où elle sera 
stockée. La chaîne est de longueur inconnue et 
se termine par un caractère de retour. Lorsqu'elle 
est stockée, le caractère de retour est supprimé, 
et un octet indiquant la longueur de la chaîne est 
ajouté à son début. 


$3000 TABLE contient le nombre de 
$1000 valeurs. 

() NEGS est là où on garde le 
TABLE compte des valeurs négatives. 
#TABLE L'adresse du tableau va en X. 


B,X Prend la dernière valeur du 
tableau. 

Aller en ENDLP si la valeur 
est positive. 

Sinon, compter si la valeur est 
négative. 

Compte à rebours sur le 
tableau. 

Ÿ at-il encore des valeurs ? 
Si oui, aller en LOOP. 
Sinon, retourner au système 
d'exploitation. 

Valeur ASCII du caractère de 
retour chariot. 

Adresse du tampon d'entrée. 
STRINGZ contient l'adresse 
de l'espace libre. 


Adresse de chaîne source 
(c'est-à-dire $3000 d'abord) 
chargée en X. 


Adresse de chaîne destination 
(c'est-à-dire adresse stockée 
en $10,$11) en Y. 


Transférer l'adresse de l'octet 
de longueur en U. 


Stocker zéro au premier octet 
de chaîne destination. 


Prendre le caractère suivant 
du tampon d'entrée. 

Est-ce un caractère de retour ? 
Arrêter si oui. 

Sinon, le copier let} 
Additionner 1 à la longueur. 
Caractère suivant. 

Retour au système 
d'exploitation. 


ENDLP 


NEGS 


CR 13 


STRING1 
STRING2 


$3000 
$0010 
$1000 
#STRINGI 


STRING2 


#CR 
FINISH 


Ni 


FINISH 
END 


Compteur 
de valeurs 
négatives 


Un tableau de valeurs à 
8 bits est stocké à 
l'emplacement 001. 

Le nombre de valeurs du 
tableau est stocké en 300 
et est supposé inférieur 
à 256. Le programme 
compte le nombre de 
valeurs négatives dans 

le tableau. 


Copieur 
de chaîne 
de caractères 


Ce programme copie 
une chaîne à partir du 
tampon d'entrée en 5300 
vers le prochain espace 
de chaîne libre, dont 
l'adresse est donnée 
en $0010. 
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Un tuyau en or 

A tout moment, les joueurs 
peuvent consulter le 
programme des courses 
(image du haut), lequel 
donne des renseignements 
précis sur chacune d'elles 
et signale combien elle 
peut rapporter. Une fois les 
chevaux sélectionnés en 
vue d’une épreuve 
particulière, il est possible 
de parier sur tel ou tel 
animal (deuxième image). 
Les montures sont alignées 
en attendant le signal du 
starter, et les joueurs n'ont 
plus qu'à contempler la 
course. La dernière image 
montre l’arrivée au poteau : 
le cheval de notre 
photographe a péniblement 
terminé quatrième... 
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Vous n'êtes peut-être pas amateur de courses de chevaux. 
Mais Classic Racing, de Salamander Software, destiné à l’Oric-1 
et à l’Atmos, saura pourtant vous retenir. 


Classic Racing fait de vous un entraîneur de che- 
vaux de course le temps d’une saison complète. 
Le jeu est prévu pour un maximum de six 
joueurs, mais lorsque ce nombre n’est pas atteint, 
l’ordinateur prend la place des absents. Vous 
pouvez par ailleurs fixer vous-même la durée de 
la saison, qui peut comporter jusqu’à seize réu- 
nions différentes, chacune donnant lieu à six 
courses. Les joueurs peu audacieux pourront tou- 
jours choisir un calendrier moins chargé. 

L'objectif est simple : gagner le plus d’argent 
possible. On peut y arriver soit en plaçant un de 
ses propres chevaux parmi les trois premiers, ce 
qui rapporte un prix, soit en pariant sur les résul- 
tats. Vous devez obligatoirement faire participer 
une de vos montures à chaque course, mais rien 
ne vous empêche de parier sur un autre 
concurrent si vous estimez que cela peut être 
profitable. 

Votre écurie compte seize chevaux, et en début 
de saison, vous n’avez encore aucune idée pré- 
cise de leurs mérites respectifs. Toutefois, c’est 
une époque où il n’y a encore que des compéti- 
tions peu importantes; vous pouvez donc vous 
livrer à des estimations en faisant courir vos bêtes 
sur des longueurs différentes ou sur des terrains 
très variables. Il ne s’agit encore que d’essais : 
voyez comment un cheval se comporte dans des 
conditions données et établissez votre stratégie en 
fonction des résultats. Naturellement, cela vous 
obligera à prendre énormément de notes : à cha- 
que course vous devrez coucher par écrit la dis- 
tance, le poids du jockey, l’état du terrain et, bien 
sûr, le résultat final. (Il est regrettable que Sala- 
mander Software n’ait pas jugé utile d’intégrer 
une routine qui aurait géré automatiquement tou- 
tes ces données; le jeu en aurait été bien plus 
simple.) 

En vue de la première réunion, vous choisis- 
sez les six chevaux que vous y engagerez, et l’ordi- 
nateur vous indiquera le nom des concurrents 
ainsi que le poids qu’ils portent. Ensuite il pren- 
dra les paris. En début de saison, les cotes 
semblent être attribuées un peu au hasard; 
mais, au fil du temps, elles se font de plus en 
plus précises. 

Les paris peuvent rapporter gros. Un cheval 
gagnant (ou placé) vaut également un prix en 
argent ; il est donc parfois intéressant de parier 
sur l’un de vos adversaires, vous pouvez faire 
ainsi d’une pierre deux coups. 

Rien ne vous empêche par ailleurs de monter 
de véritables « coups », par exemple en engageant 
un cheval dans une course où, de toute évidence, 


il n’a aucune chance : une monture qui se com- 
porte bien en terrain lourd et sur une courte dis- 
tance pourra ainsi être lancée à deux reprises sur 
un parcours de 2 800 m en terrain sec. 

Le but de la manœuvre est de la faire perdre 
délibérément, donc d’abaisser sa cote, puis de lui 
faire retrouver son type de réunion préféré. Pour- 
tant, une fois que vous aurez déterminé quelle 
est la distance et le terrain qui conviennent le 
mieux à tel ou tel cheval, résistez à la tentation 
de lui faire courir course après course : il aura 
besoin de repos si vous voulez qu’il donne toute 
sa mesure. 

Une fois les paris enregistrés, l’action com- 
mence pour de bon. Les chevaux prennent la 
position, le speaker les appelle l’un après l’autre, 
et la course commence. Le programme donne une 
bonne approximation sonore des encouragements 
lancés par les turfistes, tandis que chaque 
concurrent s’efforce de l’emporter. Rien de plus 
insupportable que de voir votre candidat s’effon- 
drer à 300 m de l’arrivée, pendant que le favori 
s’envole littéralement ! 

Après, les gagnants empochent leurs gains, et 
le jeu reprend jusqu’à la fin de la réunion. Cha- 
cune d’elles propose des distances et des terrains 
très différents, et si vous estimez qu’un de vos 
candidats n’est pas à la hauteur, il vous suffira 
de déclarer forfait lors de trois réunions succes- 
sives. Vos calculs s’en trouveront simplifiés, mais 
vous serez contraint de payer une pénalité de 
1 000 livres à chaque nouvelle rencontre. 

Vers la fin de la saison, la compétition se fait 
plus difficile. En contrepartie, les récompenses 
sont de plus en plus importantes : lors du fameux 
derby d’Epsom, couru lors de la toute dernière 
réunion, les trois premiers concurrents se parta- 
gent une « grosse galette ». 

Classic Racing est à ce jour le meilleur pro- 
gramme jamais réalisé pour l’Oric-1 et l’Oric 
Atmos. Les courses, en particulier du point de 
vue graphique, sont tout à fait remarquables. Par 
ailleurs, l’obligation de planifier une saison de 
courses tout entière donne à ce jeu un intérêt tou- 
jours renouvelé. 

Il est théoriquement possible de « faire for- 
tune » en une saison. 
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